1.  Superivisor简介:

    Supervisor是一个C/S系统,它允许用户在类UNIX系统上监控和管理一系列的进程。你可以把一个进程以Daemon的形式用Supervisor来管理。


2.  安装:

    使用pip来安装Supervisor:

[root@test1 ~]# pip install supervisor

    如果CentOS系统中没用安装pip,可以通过如下命令安装pip:

[root@test1 ~]# yum -y install python-pip


3.  配置文件:

    Supervisor的配置文件需要手动执行命令来生成,如下:

[root@test1 ~]# echo_supervisord_conf > /etc/supervisord.conf


4.  常用的配置项:

command=/bin/cat                 ---- 启动程序时执行的命令;
directory=/tmp                   ---- 执行目录,若有/home/test/test1.py,将directory设置成/home/test,则command只需设置成python test1.py。否则command必须设置成绝对路径;
process_name=%(program_name)s     ---- 进程启动,使用program name作为进程名,默认值;
autostart=true                   ---- 随Supervisor启动一起启动;
startsecs=1                      ---- 等待多长时间后认为程序启动成功,默认为1;
startretries=3                   ---- 启动失败时的重试次数,默认为3;
user=root                        ---- 以root身份运行程序;
priority=999                     ---- 优先级。值越高,最后启动,最先被关闭,默认值999。


5.  命令:

Supervisor有两个可执行程序 :supervisord 和 supervisorctl。

    supervisord用来依据配置文件的策略管理后台守护进程;

    supervisorctl管理员用于向后台守护进程发送“启动/重启/停止”等指令。


6.  一个例子,使用Supervisor管理一个Python Flask程序hello.py:

[program:flasky]
directory=/opt/flasky/
command=/opt/flasky/venv/bin/python hello.py runserver --host 192.168.1.101 -p 8080
autostart=true
startsecs=10
startretries=2
user=root
stderr_logfile=/tmp/flasky-error.log
stdout_logfile=/tmp/flasky-error.log


7.  启动Supervisord:

[root@test1 ~]# /usr/bin/supervisord -c /etc/supervisord.conf


8.  查看进程状态:

[root@test1 ~]# /usr/bin/supervisorctl status
flasky                           STARTING                           
[root@test1 ~]# /usr/bin/supervisorctl status
flasky                           RUNNING   pid 46778, uptime 0:00:10
[root@test1 ~]# /usr/bin/supervisorctl status
flasky                           RUNNING   pid 46778, uptime 0:00:13


9.  Supervisorctl管理命令:

supervisorctl status                ---- 查看supervisor管理进程的状态;
supervisorctl stop programname      ---- 用来关闭某个进程,programname指上例中的flasky;
supervisorctl start programname     ---- 用来启动某个进程;
supervisorctl restart programname   ---- 用来重启某个进程;
supervisorctl stop all              ---- 关闭所有的进程;
supervisorctl reload                ---- 停止所有进程,载入最新的配置文件,并根据最新的配置启动、管理进程;
supervisorctl update                ---- 根据最新的配置文件,启动新配置的进程或重启配置有变化的进程,没有改动过的进程不会受到影响;
supervisorctl shutdown              ---- 关闭supervisor服务。


10、执行supervisorctl时异常:

error: <class 'xmlrpc.client.ProtocolError'>, <ProtocolError for 127.0.0.1/RPC2: 404 Not Found>: file:

这时可以在执行supervisorctl时通过-c选项指定配置文件的位置:

[root@test1 ~]# /usr/bin/supervisorctl -c /etc/supervisord.conf status


    曾经有一次面试,面试官提问:“有一个脚本,如何让它在开机之后一小时的时候开始执行?”

    我答:“在脚本开头加上‘sleep 3600’,再把脚本加入rc.d目录开机启动。”

    其实,用Supervisor就可以更合理地实现。