作者在引入conf/global 文件时,就已经对操作系统的类型进行判断,同时也对DISTRO进行了赋值。

部分代码,如图:

显然文件里的KERNEL_NAME的值就是判断完成的操作系统,具体分析该值是如何得到的。

就是通过命令“uname –s  | tr ‘[a-z]’ ‘[A-Z]’得到的,不过作者在此处把小写换成了大写。 接下来分析根据不同操作系统,怎么获得不同的DISTRO值,代码如下:

if [ X"${KERNEL_NAME}" == X'LINUX' ]; then
# Directory of RC scripts.
export DIR_RC_SCRIPTS='/etc/init.d' if [ -f /etc/redhat-release ]; then
# RHEL/CentOS
export DISTRO='RHEL' # Get distribution version
if grep '\ 6' /etc/redhat-release &>/dev/null; then
# version .x
export DISTRO_VERSION=''
elif grep '\ 7' /etc/redhat-release &>/dev/null; then
# version .x
export DISTRO_VERSION=''
else
export UNSUPPORTED_RELEASE='YES'
fi # Get distribution name as DISTRO_CODENAME
if grep '^Red' /etc/redhat-release &>/dev/null; then
# RHEL
export DISTRO_CODENAME='rhel'
elif grep '^CentOS' /etc/redhat-release &>/dev/null; then
# CentOS
export DISTRO_CODENAME='centos'
elif grep '^Scientific' /etc/redhat-release &>/dev/null; then
# Scientific Linux
export DISTRO_CODENAME='scientific'
else
export UNSUPPORTED_RELEASE='YES'
fi elif [ -f /etc/lsb-release ]; then
# Ubuntu
export DISTRO='UBUNTU' # Ubuntu version number and code name:
# - 14.04: trusty
# - 15.04: vivid
export DISTRO_ID="$(grep 'DISTRIB_ID' /etc/lsb-release | awk -F'=' '{print $2}')"
export DISTRO_VERSION="$(grep 'DISTRIB_RELEASE' /etc/lsb-release | awk -F'=' '{print $2}')"
export DISTRO_CODENAME="$(grep 'DISTRIB_CODENAME' /etc/lsb-release | awk -F'=' '{print $2}')" # Unsupported releases: .x, .x, 14.10
if echo "${DISTRO_VERSION}" | grep -E '^(12|13|14\.10)' &>/dev/null ; then
export UNSUPPORTED_RELEASE='YES'
fi
elif [ -f /etc/debian_version ]; then
# Debian
export DISTRO='DEBIAN' # Get major release version number
export DISTRO_VERSION="$(cat /etc/debian_version)" # Set distro code name and unsupported releases.
if grep '^7' /etc/debian_version &>/dev/null || \
grep -i '^wheezy' /etc/debian_version &>/dev/null; then
export DISTRO_VERSION=''
export DISTRO_CODENAME='wheezy'
elif grep '^8' /etc/debian_version &>/dev/null || \
grep -i '^jessie' /etc/debian_version &>/dev/null; then
export DISTRO_VERSION=''
export DISTRO_CODENAME='jessie'
else
export UNSUPPORTED_RELEASE='YES'
fi # Override settings.
export SHELL_NOLOGIN='/usr/sbin/nologin'
else
export UNSUPPORTED_RELEASE='YES'
fi
elif [ X"${KERNEL_NAME}" == X'FREEBSD' ]; then
export DISTRO='FREEBSD'
export DISTRO_VERSION="$(uname -r |awk -F'[.-]' '{print $1}')" # Directory of RC scripts.
export DIR_RC_SCRIPTS='/usr/local/etc/rc.d'
export PYTHON_BIN='/usr/local/bin/python' # Unsupported releases: , .
if echo "${DISTRO_VERSION}" | grep '^[78]' &>/dev/null ; then
export UNSUPPORTED_RELEASE='YES'
fi export SHELL_BASH='/usr/local/bin/bash' # Default password scheme.
export DEFAULT_PASSWORD_SCHEME='BCRYPT' elif [ X"${KERNEL_NAME}" == X'OPENBSD' ]; then
export DISTRO='OPENBSD'
export DISTRO_VERSION="$(uname -r)" # Directory of RC scripts.
export DIR_RC_SCRIPTS='/etc/rc.d'
export RC_CONF_LOCAL='/etc/rc.conf.local'
export SHELL_BASH='/usr/local/bin/bash'
export PYTHON_BIN='/usr/local/bin/python' # Unsupported release: 5.6 and earlier versions.
if echo "${DISTRO_VERSION}" | grep '^5.[123456]' &>/dev/null ; then
export UNSUPPORTED_RELEASE='YES'
fi # Default password scheme.
export DEFAULT_PASSWORD_SCHEME='BCRYPT' else
# Not support *BSD and other distrobutions yet.
echo "Error: Your OS is not supported yet."
exit
fi

代码比较长,不过脉络比较清晰,首先根据KERNEL_NAME的值判断是哪种操作系统,作者给出的判断是3种,分别是LINUX   OPENBSD   FREEBSD  , 也就是该脚本只能在这3种平台上进行部署,如果需要自己扩展的话,就可以在增加新的判断,最后如果3种都不是的话,就直接返回255,如下代码:

echo "Error: Your OS is not supported yet."
exit

接下来分析当KERNEL_NAME的值为LINUX,脚本做了什么,首先定义了一个变量

export DIR_RC_SCRIPTS='/etc/init.d'

linux中一般启动脚本都是放在这个目录里的,LINUX本身也有很多版本,因此作者在此处又进行多种类型的判断,判断的依据文件分别是/etc/redhat-release  /etc/lsb-release  /etc/debian_version这3种文件分别对应rhel/centos  ubuntu  debian  , 从而也说明在LINUX的版本中,只支持这3种,其他的LINUX版本是不支持的,最后作者返回一句代码:

定义了一个UNSUPPORTED_RELEASE变量,在后续的代码应该会调用这个变量来判断是否支持。

针对这3种LINUX,作者又具体细分到不同的小版本中,首先看rhel/centos 系列,下面代码:

首先根据存在redhat-release文件,定义了DISTRO的值

if [ -f /etc/redhat-release ]; then
export DISTRO='RHEL'

这样在get_all.sh的脚本里调用时就有了判断依据,接着判断具体的版本,

if grep '\ 6' /etc/redhat-release &>/dev/null; then
# version .x
export DISTRO_VERSION=''
elif grep '\ 7' /etc/redhat-release &>/dev/null; then
# version .x
export DISTRO_VERSION=''
else
export UNSUPPORTED_RELEASE='YES'
fi

显然只支持6和7两个版本,也就是安装时,如果不是这2个版本的话,就会返回unsupport_release的值为YES了。

rhel还有两个个反编译版本即centos ,Scientific Linux,    因此作者又定义了一个变量来区别 DISTRO_CODENAME, 代码如下:

if grep '^Red' /etc/redhat-release &>/dev/null; then
# RHEL
export DISTRO_CODENAME='rhel'
elif grep '^CentOS' /etc/redhat-release &>/dev/null; then
# CentOS
export DISTRO_CODENAME='centos'
elif grep '^Scientific' /etc/redhat-release &>/dev/null; then
# Scientific Linux
export DISTRO_CODENAME='scientific'
else
export UNSUPPORTED_RELEASE='YES'
fi

显然在/etc/redhat-release文件里,不同的发行版本有不同的关键字,这样关于红帽系的操作系统,作者就已经区分完毕了。


接下来关于ubuntu的判断就简单多了,看图

根据/etc/lsb-release的文件是否存在,赋值DISTRO为UBUNTU,然后判断具体版本,看代码

        export DISTRO_ID="$(grep 'DISTRIB_ID' /etc/lsb-release | awk -F'=' '{print $2}')"
export DISTRO_VERSION="$(grep 'DISTRIB_RELEASE' /etc/lsb-release | awk -F'=' '{print $2}')"
export DISTRO_CODENAME="$(grep 'DISTRIB_CODENAME' /etc/lsb-release | awk -F'=' '{print $2}')" # Unsupported releases: .x, .x, 14.10
if echo "${DISTRO_VERSION}" | grep -E '^(12|13|14\.10)' &>/dev/null ; then
export UNSUPPORTED_RELEASE='YES'
fi

从程序可以看出UBUNTU的ID ,  RELEASE ,  CODENAME的值都在/etc/lsb-release的文件里,用grep 和awk匹配后,赋予不同变量的值。

用grep 筛选出系统版本为12,13,14.10的都为不支持版本,目前支持的版本为14.04,15.04


接下来判断的就是DEBIAN了,同样是判断文件,如图:

文件存在,则DISTRO的值为DEBIAN,接下来判断版本号:

# Get major release version number
export DISTRO_VERSION="$(cat /etc/debian_version)"

cat /etc/debian_version  一个命令就可以得到具体版本,比rhel更容易判断

接下来对具体版本进行判断,见代码:

# Set distro code name and unsupported releases.
if grep '^7' /etc/debian_version &>/dev/null || \
grep -i '^wheezy' /etc/debian_version &>/dev/null; then
export DISTRO_VERSION=''
export DISTRO_CODENAME='wheezy'
elif grep '^8' /etc/debian_version &>/dev/null || \
grep -i '^jessie' /etc/debian_version &>/dev/null; then
export DISTRO_VERSION=''
export DISTRO_CODENAME='jessie'
else
export UNSUPPORTED_RELEASE='YES'
fi

显然只支持DEBIAN的7,8两个版本,到此DISTRO的值和操作系统的判断结束,如果想新增特殊操作系统的话或者自己定义的话,在此处加入自己的代码即可。

iredmail安装脚本分析(三)---conf/global DISTRO值的来源及操作系统的判断的更多相关文章

  1. iredmail安装脚本分析(二)---get_all.sh 文件所在目录为PKGS

    经过上面的一系列分析后,进入到获取安装包的步骤,作者在此处单独写了一个脚本,get_all.sh,我们继续分析这个脚本 _ROOTDIR="$(pwd)" CONF_DIR=&qu ...

  2. iredmail安装脚本分析(一)---iRedmail.sh

    iredmail是一套以postfix为核心的整合邮件系统的安装脚本,可以达到快速部署邮件服务器的目的.为了让自己不遗忘shell的语法,所以闲来无事,学习一下他的代码. 我从官网下载他的最新版,解压 ...

  3. fabric-network_setup.sh安装脚本分析

    在进行镜像安装前,提供了一个sample脚本的下载,可以使用该脚本进行容器的启停.这里对该脚本进行分析. fabric/release/linux-amd64/network_setup.sh 脚本提 ...

  4. fabric镜像安装脚本分析

    #!/bin/bash # # Copyright IBM Corp. All Rights Reserved. # # SPDX-License-Identifier: Apache-2.0 # e ...

  5. centos 邮件服务 腾讯企业邮箱(免费) 使用iRedmail 需要有公网的centos主机 发邮件协议:smtp 端口25 收邮件协议:pop3 端口110 iredmail安装配置 使用邮箱系统 第三十一节课

    centos   邮件服务  腾讯企业邮箱(免费) 使用iRedmail 需要有公网的centos主机 发邮件协议:smtp 端口25  收邮件协议:pop3 端口110  iredmail安装配置 ...

  6. centos shell编程5 LANMP一键安装脚本 lamp sed lnmp 变量和字符串比较不能用-eq cat > /usr/local/apache2/htdocs/index.php <<EOF重定向 shell的变量和函数命名不能有横杠 平台可以用arch命令,获取是i686还是x86_64 curl 下载 第三十九节课

    centos shell编程5  LANMP一键安装脚本 lamp  sed  lnmp  变量和字符串比较不能用-eq  cat > /usr/local/apache2/htdocs/ind ...

  7. Hi3516开发笔记(三):Hi3516虚拟机基础环境搭建之交叉编译环境境搭建以及开机启动脚本分析

    前言   前面进行了可以传输,那么写一个简单的C程序来交叉编译并传入运行.   虚拟机   上一篇搭建的虚拟机环境,包含了sftp传递文件,网络能ping通,基于上一篇的虚拟机继续搭建.   海思交叉 ...

  8. Selenium(十七):unittest单元测试框架(三) 脚本分析、编写Web用例

    1. 带unittest的脚本分析 也许你现在心里还有疑问,unittest框架与我们前面所编写的Web自动化测试之间有什么必然联系吗?当然有,既然unittest可以组织.运行测试用例,那么为什么不 ...

  9. Hadoop的shell脚本分析

    你会发现hadoop-daemon.sh用于启动单独的本机节点 而hadoop-daemons.sh 会批量的ssh到别的机器启动 前记: 这些天一直学习hadoop,学习中也遇到了许多的问题,主要是 ...

随机推荐

  1. 滑动式折叠菜单 - Slashdot's Menu

    折叠菜单让你在尽可能小的地方放置尽可能多的内容,同时加大了操作的简便性,因此,深受前台设计师的喜爱.随着大家对动画效果的钟爱,折叠菜单也开始“动”起来了,本文介绍的就是 DimX 制作的滑动式折叠菜单 ...

  2. centOS 6.7 中安装matlab R2014b

    参考资料: [1] http://www.centoscn.com/image-text/config/2014/1222/4354.html 系统: centOS 6.7 2.6.32-573.el ...

  3. Imagick 缩放图片和实现模糊

    Imagick功能相当的多,只是还不稳定,我下面的程序能够运行,但是会出现内存错误,但我们要的图片还是能够得到. 弄这个的原因是,一个客户要求在一个appcan的应用里面实现一个页面的背景图的缩放.调 ...

  4. python学习08——类

    笨办法学python第42节,这节讲的是类,程序沿用上一节中一个游戏,不同的是这一节用了类的方法. 其中改动的代码主要如下 原来的最后几句用了这样的代码: ROOMS = { 'death':deat ...

  5. php上传文件类型

    下面提供一张IE和火狐浏览器的文件类型对照表: ie 火狐 id 后缀名 php识别出的文件类型 0 gif image/gif 1 jpg image/jpeg 2 png image/png 3 ...

  6. 作业3(PSP表格)

                            PSP2.1 Personal Software Process Stages Time(min) Planning 计划 11 Estimate 估计 ...

  7. memset函数详解

    语言中memset函数详解(2011-11-16 21:11:02)转载▼标签: 杂谈 分类: 工具相关  功 能: 将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值, 块的大 ...

  8. C++之虚函数和多态

    干货较多-需要自己深思理解: C++支持两种多态性: 1.编译时多态性(静态绑定-早绑定) 在程序编译阶段即可以确定下来的多态性 通过使用 重载机制(重载函数)实现 (模板)http://blog.c ...

  9. 【转】输入/输出流 - 深入理解Java中的流 (Stream)

    基于流的数据读写,太抽象了,什么叫基于流,什么是流?Hadoop是Java语言写的,所以想理解好Hadoop的Streaming Data Access,还得从Java流机制入手.流机制也是JAVA及 ...

  10. SpellTime

    如果你的应用程序允许用户输入文本,或者它结合了任何基于文本的处理,那么我们有一款你一直寻找的产品.Spell Time 允许你把个拼写检查器整合到你的产品中.该产品携带了完整的源码.Spell Tim ...