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就可以更合理地实现。