跳到主要内容

supervisor自定义服务文件参数

supervisor配置文件 /etc/supervisor/supervisord.conf 中定义了include,因此如果想要管理服务,就需要编辑 /etc/supervisor/config.d/*.ini 文件,以下为 /etc/supervisor/config.d/*.ini 文件中用到的参数

参数说明
command启动程序使用的命令,可以是绝对路径或者相对路径
process_name一个python字符串表达式,用来表示supervisor进程启动的这个的名称,默认值是%(program_name)s
numprocsSupervisor启动这个程序的多个实例,如果numprocs>1,则process_name的表达式必须包含%(process_num)s,默认是1
numprocs_start一个int偏移值,当启动实例的时候用来计算numprocs的值
priority权重,可以控制程序启动和关闭时的顺序,权重越低:越早启动,越晚关闭。默认值是999
autostart如果设置为true,当supervisord启动的时候,进程会自动重启
autorestart值可以是false、true、unexpected。false:进程不会自动重启,unexpected:当程序退出时的退出码不是exitcodes中定义的时,进程会重启,true:进程会无条件重启当退出的时候
startsecs程序启动后等待多长时间后才认为程序启动成功
startretriessupervisord尝试启动一个程序时尝试的次数。默认是3
exitcodes一个预期的退出返回码,默认是0,2
stopsignal当收到stop请求的时候,发送信号给程序,默认是TERM信号,也可以是 HUP, INT, QUIT, KILL, USR1, or USR2
stopwaitsecs在操作系统给supervisord发送SIGCHILD信号时等待的时间
stopasgroup如果设置为true,则会使supervisor发送停止信号到整个进程组
killasgroup如果设置为true,则在给程序发送SIGKILL信号的时候,会发送到整个进程组,它的子进程也会受到影响
user如果supervisord以root运行,则会使用这个设置用户启动子程序
redirect_stderr如果设置为true,进程则会把标准错误输出到supervisord后台的标准输出文件描述符
stdout_logfile把进程的标准输出写入文件中,如果stdout_logfile没有设置或者设置为AUTO,则supervisor会自动选择一个文件位置
stdout_logfile_maxbytes标准输出log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小
stdout_logfile_backups标准输出日志轮转备份的数量,默认是10,如果设置为0,则不备份
stdout_capture_maxbytes当进程处于stderr capture mode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB
stdout_events_enabled如果设置为true,当进程在写它的stderr到文件描述符的时候,PROCESS_LOG_STDERR事件会被触发
stderr_logfile把进程的错误日志输出一个文件中,除非redirect_stderr参数被设置为true
stderr_logfile_maxbytes错误log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小
stderr_logfile_backups错误日志轮转备份的数量,默认是10,如果设置为0,则不备份
stderr_capture_maxbytes当进程处于stderr capture mode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB
stderr_events_enabled如果设置为true,当进程在写它的stderr到文件描述符的时候,PROCESS_LOG_STDERR事件会被触发
environment一个k/v对的list列表
directorysupervisord在生成子进程的时候会切换到该目录
umask设置进程的umask
serverurl是否允许子进程和内部的HTTP服务通讯,如果设置为AUTO,supervisor会自动的构造一个url

重要参数

服务自动重启设置,supervisor提供了当服务挂掉时自动重启服务的功能autorestart

autorestart可以写在supervisor配置文件中,也可以写在服务自定义文件中(supervisor配置文件中include指定的目录下的文件/etc/supervisor/config.d/*.ini

autorestart值可以是falsetrueunexpected

说明
false进程不会自动重启
unexpected当程序退出时的退出码不是exitcodes中定义的时侯,进程会重启
true当服务退出的时候进程会无条件重启

示例:

[program:nginx]
command = /usr/sbin/nginx -g 'daemon off;'
stdout_logfile = /var/log/nginx/nginx.log
redirect_stderr = true
autorestart = unexpected