Supervisor

Supervisor是一个进程监控程序。可以查看进程执行状态。

使用场景

1、我现在有一个进程需要每时每刻不断的跑,但是这个进程又有可能由于各种原因有可能中断。当进程中断的时候我希望能自动重新启动它,此时,我就需要使用到了Supervisor,相当于将一个普通后台变成了守护进程

2、有一个脚本需要自定义时间执行,可以打开Supervisor web页点击执行

等等

安装使用教程

ubuntu安装:

  1. apt-get install supervisor

以centos为例:

#安装setuptools
yum install python-setuptools

#安装supervisor
easy_install supervisor

#测试安装是否成功:
echo_supervisord_conf
#上面语句若输出配置文件信息表示安装成功

#创建supervisor配置文件
echo_supervisord_conf > /etc/supervisord.conf

#修改配置文件:
#在supervisord.conf最后增加:
[program:php]
command = php                   ;需要执行的命令
user=www                   ;设置执行用户,可以用来管理该listener进程。                           默认为空。。非必须设置
autostart=true                   ;supervisor启动的时候是否随着同时启动
autorestart=true               ;当程序跑出exit的时候,这个program会自动重启
startsecs=1                    ;程序重启时候停留在runing状态的秒数
startretries=3                   ;启动失败自动重试次数,默认是 3
redirect_stderr=true           ;把 stderr 重定向到 stdout,默认 false
stdout_logfile=/mnt/hgfs/htdocs/logs/stdout.log     ;stdout 日志文件
stderr_logfile=/mnt/hgfs/htdocs/logs/stderr.log


# 队列消费
[program:queue_dispose]
command                 = /usr/local/php/bin/php /alidata/www/artisan queue:work  --daemon --sleep=3 --tries=3
process_name            = %(program_name)s_%(process_num)s
user=www                   ;设置执行用户,可以用来管理该listener进程。
numprocs                = 6 ;启动6个进程
autostart               = true
autorestart             = true
stdout_logfile          = /alidata/log/php/supervisor_queue_dispose_out.log
stdout_logfile_maxbytes = 10MB
redirect_stderr=true

[program:dsj_spider]
command=/usr/local/php/bin/php  /mnt/hgfs/htdocs/www.test.com/index.php
user=www                   ;设置执行用户,可以用来管理该listener进程。
autostart=false
autorestart=false
startsecs=1                ;启动 1 秒后没有异常退出,就当作已经正常启动了
startretries=3
redirect_stderr=true
stdout_logfile=/mnt/hgfs/htdocs/logs/stdout.log
stderr_logfile=/mnt/hgfs/htdocs/logs/stderr.log

#除以上将进程配置添加到supervisord.conf文件中
#推荐将各个进程配置放到单独的文件中,然后通过[include]配置项引用
[include]
files = /etc/supervisor/*.conf

#其他配置具体看/etc/supervisord.conf文件
#supervisor服务启动
supervisord -c /etc/supervisord.conf

#supervisor服务客户端管理
supervisorctl

# 重新启动配置中的所有程序
sudo supervisorctl reload 

sudo supervisorctl reread

sudo supervisorctl update

# 终止配置中的所有进程

sudo supervisorctl stop all

# 启动配置中的所有进程
sudo supervisorctl start all

# 其他命令例子

sudo supervisorctl start queue_dispose:*

sudo supervisorctl -c /etc/supervisor/supervisord.conf  status

sudo supervisorctl -c /etc/supervisor/supervisord.conf stop   webWeiXinLoginList:webWeiXinLoginList_0

注意:

1、每次修改配置文件后需进入supervisorctl,执行reload, 改动部分才能生效

2、Supervisor主要有两个命令:
supervisord : 启动supervisor的服务器端
supervisorctl:启动supervisor的命令行窗口,在该命令行中可执行start、stop、status、reload等操作。

3、php脚本执行报'BACKOFF  Exited too quickly (process log may have details)'错误解决:
对于执行时间很短的php脚本,点击进程执行会报以上错误

<?php
require 'db.class.php';

$dbHost = 'localhost';
$dbUser = 'xxxxxx';
$dbPasswd = 'xxxxxx';
$dbName = 'test';

$pdo = db::getInstance($dbHost, $dbUser, $dbPasswd, $dbName);

$pdo->insert('test', ['name' => 'wml']);

sleep(2);   #在php脚本最后一行加上一句,可解决该问题

亮点:web管理界面

supervisor提供web管理页面,可以在网页端对进程进行监控,启动,终止,重启等操作

将supervisord.conf中[inet_http_server]部分做相应配置,在supervisorctl中reload即可启动web管理界面

[inet_http_server]           ; inet (TCP) server disabled by default
port=192.168.10.129:9001     ; 外网ip(ip_address:port specifier, *:port for all iface)
username=xxxxxxx             ; (default is no username (open server))
password=xxxxxxx             ; (default is no password (open server))

在浏览器打开网址192.168.10.129:9001,输入上面账号xxxxxxx密码xxxxxxx,即可进入web管理页面:

.linux后台进程管理工具:supervisor - 图1

supervisor缺点

1. 单机监控

2. 只能从supervisor启动的程序才能监控,从其他地方启动的无法监控

3. 需要指出的是,被 Supervisor 管理的进程,不能使用 daemon 模式,而必须在前台运行,否则会报错。

进程数限制

supervisor进程描述符默认为200,对于管理需要更多进程描述符的子进程一定要修改配置文件
/etc/supervisor/supervisord.conf, 在[supervisord]下面添加minfds=102400(改大即可)。

也就是说默认supervisor最多可以开启200个子进程,要开启更多需要配置参数。

可以使用阿里云监控 supervisord 进程, supervisord进程 监控各子进程

其他监控工具如 monit ,功能更加强大。等以后研究

其他文章:
supervisor配置详解