Supervisor
Supervisor是一个进程监控程序。可以查看进程执行状态。
使用场景
1、我现在有一个进程需要每时每刻不断的跑,但是这个进程又有可能由于各种原因有可能中断。当进程中断的时候我希望能自动重新启动它,此时,我就需要使用到了Supervisor,相当于将一个普通后台变成了守护进程
2、有一个脚本需要自定义时间执行,可以打开Supervisor web页点击执行
等等
安装使用教程
ubuntu安装:
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管理页面:
supervisor缺点
1. 单机监控
2. 只能从supervisor启动的程序才能监控,从其他地方启动的无法监控
3. 需要指出的是,被 Supervisor 管理的进程,不能使用 daemon 模式,而必须在前台运行,否则会报错。
进程数限制
supervisor进程描述符默认为200,对于管理需要更多进程描述符的子进程一定要修改配置文件
/etc/supervisor/supervisord.conf, 在[supervisord]下面添加minfds=102400(改大即可)。
也就是说默认supervisor最多可以开启200个子进程,要开启更多需要配置参数。
可以使用阿里云监控 supervisord 进程, supervisord进程 监控各子进程
其他监控工具如 monit ,功能更加强大。等以后研究
其他文章:
supervisor配置详解