# 该函数有二个作用:
 
# 1、根据给定的二进制运行程序,找出该程序的进程号(PID)。
# 2、判断该二进制程序的运行状态,输出不同的返回値,供查看一个程序的运行状态时使用。
# __proc_pids {program} [pidfile]   -----> 该函数的用法
# Set $pid to pids from /var/run* for {program}.
# $pid should be declared
# local in the caller.
# Returns LSB exit code for the 'status' action.
__pids_var_run() {
        local base=${1##*/}  
        # 参数替换,使用局部变量$base 存储程序的二进制文件名。
        local pid_file=${2:-/var/run/$base.pid}  
         # 参数替换。如果调用该函数时,没有给$2或为空,将使
# 用/var/run/$base.pid作为变量 pid_file的值。
        pid=       # 设置一个全局变量,但其值为空。记录进程的PID号
        if [ -f "$pid_file" ] ; then   # 判断变量的值是否是一个文件,
                local line p
                read line < "$pid_file"  # 读取文件的内容
                for p in $line ; do  
                    [ -z "${p//[0-9]/}" -a -d "/proc/$p" ] && pid="$pid $p" 
              # 找出二进制运行程序的PID号。
              # 一个二进制可运行程序启动后,一般会在/var/run/目录下创建一个   
              # $base.pid 文件。
      #同时会把自己的进程号(PID)写到该文件中,当然有可能也会把另外的信息写到该文件中
      # 同时系统会在/proc 目录中创建一个以该二进制运行程序的PID为名称的目录
      # 该目录保存了,二进制运行程序的使用资源情况等等。
      #也有例外:/var/run/$base.pid 文件是空的。也有程序把pid文件存放在其它目
      #的。mysql
                done
                if [ -n "$pid" ]; then  
                        return 0        
                        # 如果找到进程号就返回状态码 0.代表二进制程序是运行的。
                fi
                return 1 # "Program is dead and /var/run pid file exists"   
         # 如果找不到进程号,就返回状态码 1.但是: /var/run/目录下是有pid文件的。
         # $base.pid是空的,也会找不到PID的。但是并不代表$base是不运行的。
        fi
        return 3 # "Program is not running"  
     # 如果:/var/run/ 目录上没有pid文件,就返回状态码 3 .该二进制程序是停止的。
}