一. 简述:
Supervisor是一个进程控制系统. 它允许用户去监控和控制在类UNIX系统的进程. 它的目标与launchd, daemontools和runit有些相似, 但是与它们不一样的是, 它不是作为init(进程号pid是1)运行. 它是被用来控制进程, 启动方式和一般程序一样。
二. Supervisor:
1. 安装:
yum install -y supervisor
服务会启动supervisord服务,它负责调用自己启动子程序,响应来自客户端的命令,重启crash或者退出的进程,记录进程的输出信息,收集事件信息。
supervisorctl:
客户端的命令行工具,提供一个类shell接口,通过它你可以连接到不同的supervisord进程上来管理它们各自的子程序。客户端命令通过UNIX socket或者TCP来和服务通讯,服务端可以要求客户端提供身份验证之后才能进行操作([supervisorctl])。
2. 配置案例:
#echo_supervisord_conf > /etc/supervisord.conf
#cat /etc/supervisord.conf
[unix_http_server]
file=/tmp/supervisor.sock ; (the path to the socket file)
[supervisord]
logfile=/tmp/supervisord.log ; (main log file;default $CWD/supervisord.log)
logfile_maxbytes=50MB ; (max main logfile bytes b4 rotation;default 50MB)
logfile_backups=10 ; (num of main logfile rotation backups;default 10)
loglevel=info ; (log level;default info; others: debug,warn,trace)
pidfile=/tmp/supervisord.pid ; (supervisord pidfile;default supervisord.pid)
nodaemon=false ; (start in foreground if true;default false)
minfds=1024 ; (min. avail startup file descriptors;default 1024)
minprocs=200 ; (min. avail process descriptors;default 200)
[rpcinterface:supervisor]
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
[supervisorctl]
serverurl=unix:///tmp/supervisor.sock ; use a unix:// URL for a unix socket
#自定义
[program:nginx2]
command=/xiao/nginx_2/sbin/nginx
[program:nginx3]
user=web #使用web用户启动服务
command=/xiao/nginx_3/sbin/nginx
启动supervisord:
/usr/bin/supervisord -c /etc/supervisord.conf
验证:
kill掉测试的nginx服务, 会发现会自动重新启动(看进程号)
手动重启方式:
1.# supervisorctl stop nginx2
2.# /xiao/nginx_2/sbin/nginx -s stop
# /xiaoxiang/nginx_2/sbin/nginx (直接通过supervisorctl start会报: nginx2: ERROR (spawn error) )
3 #supervisorctl start nginx2
官网:http://supervisord.org/introduction.html