zoukankan      html  css  js  c++  java
  • 每天一个脚本解析day1==》《service xxxxx status》之service脚本解析

    vim    /sbin/service

    #!/bin/sh

    . /etc/init.d/functions #读取环境变量.

    VERSION="$(basename $0) ver. 0.91" #"service[获取的第一个参数] ver. 0.91"对应后面的"service -V"
    USAGE="Usage: $(basename $0) < option > | --status-all |
    [ service_name [ command | --full-restart ] ]" #打印第一个参数和帮助信息.
    SERVICE= #为空
    SERVICEDIR="/etc/init.d" #service目录变量赋值
    OPTIONS= #为空

    if [ $# -eq 0 ]; then #参数数等于0,# service 命令后直接输出$USAGE
    echo "${USAGE}" >&2{这个看博客上一篇文章解释}
    exit 1 #错误返回码,因为缺少参数所以用这个
    fi

    cd / #进入"/"目录
    while [ $# -gt 0 ]; do #如果参数大于0
    case "${1}" in
    --help | -h | --h* ) #第一个参数为这3种其一
    echo "${USAGE}" >&2 #打印输出$USAGE
    exit 0 #正确返回码.
    ;;
    --version | -V ) #第一个参数为这2种其一
    echo "${VERSION}" >&2 #输出"service ver. 0.91"即$VERSION变量
    exit 0 #返回正确代码.
    ;;
    *)
    if [ -z "${SERVICE}" -a $# -eq 1 -a "${1}" = "--status-all" ]; then #$SERVICE为空且只有一个"--status-all"参数
    cd ${SERVICEDIR} #进入"/etc/init.d"目录
    for SERVICE in * ; do #$SERVICE获得程序脚本.
    case "${SERVICE}" in
    functions | halt | killall | single| linuxconf| kudzu)
    ;; #若程序脚本是这些什么都不做
    *)
    if ! is_ignored_file "${SERVICE}"
    && [ -x "${SERVICEDIR}/${SERVICE}" ]; then #"-x" FILE exists and execute (or search) permission is granted
    env -i PATH="$PATH" TERM="$TERM" "${SERVICEDIR}/${SERVICE}" status #-i, --ignore-environment(start with an empty environment)
    #env -i PATH="$PATH" TERM="$TERM" /etc/init.d/rsyslog status 等同于 /etc/init.d/rsyslog status
    fi
    ;;
    esac
    done
    exit 0
    elif [ $# -eq 2 -a "${2}" = "--full-restart" ]; then #$SERVICE参数为2个且第二个参数为"--full-restart"
    SERVICE="${1}" #第一个参数为service名称
    if [ -x "${SERVICEDIR}/${SERVICE}" ]; then # -x FILE,FILE exists and execute (or search) permission is granted
    env -i PATH="$PATH" TERM="$TERM" "${SERVICEDIR}/${SERVICE}" stop #等同于/etc/init.d/rsyslog stop,这个意思为新启个shell环境(可能,待研究)
    env -i PATH="$PATH" TERM="$TERM" "${SERVICEDIR}/${SERVICE}" start
    exit $? #返回上一个命令的正确或错误代码
    fi
    elif [ -z "${SERVICE}" ]; then #$SERVICE长度为0,这种考虑在内,一般不会出现.
    SERVICE="${1}" #$SERVICE变量为第一个参数,获取service后的第一个参数
    else
    OPTIONS="${OPTIONS} ${1}" #$OPTIONS(为空)+第一个参数,即获取第一个参数.
    fi
    shift #shift命令每执行一次,变量的个数($#)减一,而变量值提前一位
    ;;
    esac
    done

    if [ -f "${SERVICEDIR}/${SERVICE}" ]; then #$SERVICE是个二进制文件
    env -i PATH="$PATH" TERM="$TERM" "${SERVICEDIR}/${SERVICE}" ${OPTIONS} #执行$OPTIONS选项
    else
    echo $"${SERVICE}: unrecognized service" >&2 #否则打印左移的第一个参数为不可识别服务,./service yy==>yy: unrecognized service
    exit 1 #返回错误代码
    fi

    ========================================================================================================== 

    Shell重定向&>file、2>&1、1>&2的区别 (2014-07-11 16:49:24)
    shell上:
    0表示标准输入
    1表示标准输出
    2表示标准错误输出
    > 默认为标准输出重定向,与 1> 相同
    2>&1 意思是把 标准错误输出 重定向到 标准输出.
    &>file 意思是把 标准输出 和 标准错误输出 都重定向到文件file中

    用例子说话:

    1. grep da * 1>&2
    2. rm -f $(find / -name core) &> /dev/null
    上面两例中的 & 如何理解,&不是放到后台执行吗?

    牛解:

    1.&>file或n>&m均是一个独立的重定向符号,不要分开来理解。

    2.明确文件和文件描述符的区别。

    3.&>file表示重定向标准输出和错误到文件
    例如:
    rm -f $(find / -name core) &> /dev/null,/dev/null是一个文件,这个文件比较特殊,所有传给它的东西它都丢弃掉。

    4.n>&m表示使文件描述符n成为输出文件描述符m的副本。这样做的好处是,有的时候你查找文件的时候很容易产生无用的信息,如:2> /dev/null的作用就是不显示标准错误输出;另外当你运行某些命令的时候,出错信息也许很重要,便于你检查是哪出了毛病,如:2>&1
    例如:
    注意,为了方便理解,必须设置一个环境使得执行grep da *命令会有正常输出和错误输出,然后分别使用下面的命令生成三个文件:
    grep da * > greplog1
    grep da * > greplog2 1>&2
    $$$$$ grep da * > greplog3 2>&1 //grep da * 2> greplog4 1>&2 结果一样 $$$$$
    #查看greplog1会发现里面只有正常输出内容
    #查看greplog2会发现里面什么都没有
    #查看greplog3会发现里面既有正常输出内容又有错误输出内容

  • 相关阅读:
    关于npm无法安装依赖包以及安装包缓慢的解决方法
    centos 上安装nodejs v8.0.0
    nginx 负载均衡
    关于前端
    递归函数
    多重循环
    闭包
    spring boot集成mybatis(2)
    spring boot集成mybatis(3)
    spring boot集成mybatis(1)
  • 原文地址:https://www.cnblogs.com/itcomputer/p/4643304.html
Copyright © 2011-2022 走看看