SUPERVISOR进程管理器配置

supervisor   常用信号  

简介

Supervisor是一个进程控制系统. 它是一个C/S系统(注意: 其提供WEB接口给用户查询和控制), 它允许用户去监控和控制在类UNIX系统的进程. 它的目标与launchd, daemontools和runit有些相似, 但是与它们不一样的是, 它不是作为init(进程号pid是1)运行. 它是被用来控制进程, 并且它在启动的时候和一般程序并无二致.

安装和配置

  • 安装
easy_install supervisor 或者 pip install supervisor  
echo_supervisord_conf > /etc/supervisord.conf  
  • 配置(/etc/supervisord.conf)
*为必须填写项
*[program:应用名称]
[program:celery-worker]

;*命令路径,如果使用python启动的程序应该为 /usr/local/python27/bin/celery --app=cmdb.celery:app worker --loglevel=INFO
;不建议放入/home/user/, 对于非user用户一般情况下是不能访问
command=/usr/local/python27/bin/celery --app=cmdb.celery:app worker --loglevel=INFO

;当numprocs为1时,process_name=%(program_name)s
;当numprocs>=2时,%(program_name)s_%(process_num)02d
process_name=%(program_name)s

;进程数量
numprocs=1

;执行目录,若有/home/supervisor_test/test1.py
;将directory设置成/home/supervisor_test
;则command只需设置成python test1.py
;否则command必须设置成绝对执行目录
directory=/root/django-dev/cmdb

;掩码:--- -w- -w-, 转换后rwx r-x w-x
umask=022

;优先级,值越高,最后启动,最先被关闭,默认值999
priority=999

;如果是true,当supervisor启动时,程序将会自动启动
autostart=true

;*自动重启
autorestart=true

;启动延时执行,默认1秒
startsecs=10

;启动尝试次数,默认3次
startretries=3

;当退出码是0,2时,执行重启,默认值0,2
exitcodes=0,2

;停止信号,默认TERM
;中断:INT(类似于Ctrl+C)(kill -INT pid),退出后会将写文件或日志(推荐)
;终止:TERM(kill -TERM pid)
;挂起:HUP(kill -HUP pid),注意与Ctrl+Z/kill -stop pid不同
;从容停止:QUIT(kill -QUIT pid)
;KILL, USR1, USR2其他见命令(kill -l),说明1
stopsignal=TERM

stopwaitsecs=10

;*以root用户执行
user=root

;重定向
redirect_stderr=false

stdout_logfile=/data/logs/out.log  
stdout_logfile_maxbytes=1MB  
stdout_logfile_backups=10  
stdout_capture_maxbytes=1MB  
stderr_logfile=/data/logs/err.log  
stderr_logfile_maxbytes=1MB  
stderr_logfile_backups=10  
stderr_capture_maxbytes=1MB

;环境变量设置
environment=A="1",B="2"

serverurl=AUTO  
  • (inethttpserver)配置说明,可以使用浏览器查看和控制进程状态
[inet_http_server]         ; inet (TCP) server disabled by default
port=0.0.0.0:9001          ; (ip_address:port specifier, *:port for all iface)  
username=user              ; 用户名 (default is no username (open server))  
password=123456               ; 密码 (default is no password (open server))  
  • celery-worker 举例
[program:celery-worker]
command=/usr/bin/celery --app=cmdb.celery:app worker --loglevel=INFO  
directory=/root/django-dev/cmdb  
user=root  
numprocs=1  
stdout_logfile=/data/logs/celery/celery-worker.log  
stderr_logfile=/data/logs/celery/celery-worker.log  
autostart=true  
autorestart=true  
startsecs=10  
stopwaitsecs = 600  
killasgroup=true  
priority=998  

启动与关闭

  • 启动
    supervisord -c /etc/supervisord.conf
  • 关闭
    supervisorctl shutdown
  • 重载配置
    supervisorctl reload

常用信号

信号名称 数字表示 说明
SIGHUP 1 终端挂起或控制进程终止。当用户退出Shell时,由该进程启动的所有进程都会收到这个信号,默认动作为终止进程。
SIGINT 2 键盘中断。当用户按下<Ctrl+C>组合键时,用户终端向正在运行中的由该终端启动的程序发出此信号。默认动作为终止进程。 
SIGQUIT 3 键盘退出键被按下。当用户按下<Ctrl+D>或<Ctrl+\>组合键时,用户终端向正在运行中的由该终端启动的程序发出此信号。默认动作为退出程序。
SIGFPE 8 发生致命的运算错误时发出。不仅包括浮点运算错误,还包括溢出及除数为0等所有的算法错误。默认动作为终止进程并产生core文件。
SIGKILL 9 无条件终止进程。进程接收到该信号会立即终止,不进行清理和暂存工作。该信号不能被忽略、处理和阻塞,它向系统管理员提供了可以杀死任何进程的方法。
SIGALRM 14 定时器超时,默认动作为终止进程。
SIGTERM 15 程序结束信号,可以由 kill 命令产生。与SIGKILL不同的是,SIGTERM 信号可以被阻塞和终止,以便程序在退出前可以保存工作或清理临时文件等。