supervisor是一套用python开发的进程管理程序,可以在浏览器页面中监控、启动、停止以及重启进程等,并且可设置进程在异常退出时自动重启。可直接通过yum安装:
yum -y install supervisor
安装后,在/etc目录下生成如下两个文件:
[root@localhost etc]# ll | grep supervisor
-rw-r--r-- 1 root root 7953 Mar 11 08:43 supervisord.conf
drwxr-xr-x 2 root root 4096 Mar 11 08:45 supervisord.d
修改其中的supervisord.conf文件,大致如下:
[inet_http_server] ;HTTP服务器,提供web管理界面
port=10.42.xx.xx:9001 ;Web管理后台运行的IP和端口,如果开放到公网,需要注意安全性
username=user ;登录管理后台的用户名
password=123 ;登录管理后台的密码
[supervisord]
logfile=/var/log/supervisor/supervisord.log ;日志文件,默认是 $CWD/supervisord.log
logfile_maxbytes=50MB ;日志文件大小,超出会rotate,默认50MB,如果为0,表示不限制
logfile_backups=10 ;日志文件保留备份数量默认10,设为0表示不备份
loglevel=info ;日志级别,默认info,其它: debug,warn,trace
pidfile=/var/run/supervisord.pid ;pid 文件
nodaemon=false ;是否在前台启动,默认是false,即以 daemon 的方式启动
minfds=1024 ;可以打开的文件描述符的最小值,默认 1024
minprocs=200 ;可以打开的进程数的最小值,默认 200
[supervisorctl]
serverurl=http://127.0.0.1:9001 ; 通过HTTP的方式连接supervisord
username=kitty
password=123
;[program:xx]是被管理的进程配置参数,xx是进程的名称
[program:xx]
command=/usr/home/www/blog/yii test/say-hello ;程序启动命令
autostart=true ; 在supervisord启动的时候也自动启动
startsecs=10 ; 启动10秒后没有异常退出,就表示进程正常启动了,默认为1秒
autorestart=true ; 程序退出后自动重启,可选值:[unexpected,true,false],默认为unexpected,表示进程意外杀死后才重启
startretries=3 ; 启动失败自动重试次数,默认是3
user=www ; 用哪个用户启动进程,默认是root
priority=999 ; 进程启动优先级,默认999,值小的优先启动
redirect_stderr=true ; 把stderr重定向到stdout,默认false
stdout_logfile_maxbytes=20MB ; stdout 日志文件大小,默认50MB
stdout_logfile_backups = 20 ; stdout 日志文件备份数,默认是10
; stdout 日志文件,需要注意当指定目录不存在时无法正常启动,所以需要手动创建目录(supervisord 会自动创建日志文件)
stdout_logfile=/var/log/blog/blog.log
stopasgroup=false ;默认为false,进程被杀死时,是否向这个进程组发送stop信号,包括子进程
killasgroup=false ;默认为false,向进程组发送kill信号,包括子进程
;包含其它配置文件
[include]
files = /etc/supervisor.d/*.ini ;可以指定一个或多个以.ini结束的配置文件
以上是各个配置项的大概介绍。配置成大概如上形式差不多就可以了,其实进程那块配置属性是有点多的,可以考虑只保留下面这些:
[program:test]
directory=/usr/home/www/test
command=/usr/home/www/test/yii site/index
autostart=true
autorestart=true
stdout_logfile=/var/log/test/test.log
这样就简洁很多,可以按照这个模板添加想要监控的各个进程。配置好后,启动程序:
#启动supervisor程序
[root@localhost ~]# supervisord -c /etc/supervisord.conf
#查看端口号
[root@localhost ~]# netstat -ntlp | grep 9001
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 10.42.xx.xx:9001 0.0.0.0:* LISTEN 24358/python
此时可以看到程序已处于监听状态,然后在浏览器地址栏输入10.42.xx.xx:9001,弹出登录窗口输入用户名user密码123就能看到监听页面了。