1,版本要求:
≥python2.4 & <python3
2,安装命令:
sudo pip install supervisor
3,配置:
mkdir /etc/supervisor
echo_supervisord_conf > /etc/supervisor/supervisord.conf
4,program配置:
为方便各个app单独维护,我自己创建了apps目录来存储各个app的配置
cd /etc/supervisor
mkdir apps
然后编辑/etc/supervisor/supervisord.conf,修改include配置项:
[include]
files = /etc/supervisor/apps/*.conf
5,启动:
用-c参数来指定supervisord.conf的参数:
supervisord -c /etc/supervisor/supervisord.conf
6,管理:
# 读取有更新(增加)的配置文件,不会启动新添加的程序
$ supervisorctl reread
# 重启配置文件修改过的程序
$ supervisorctl update
# 查看程序状态
$ supervisorctl status
# 启动程序 App_name
$ supervisorctl start App_name
# 关闭程序 App_name
$ supervisorctl stop App_name
# 重启程序 App_name
$ supervisorctl restart App_name
也可以单独执行supervisorctl,然后输入不同的命令
7,program各个常用参数:
[program:appname] ;appname配置项
directory = /path/to/excute/command ; 在哪个目录下执行命令
command = dotnet testapi.dll ; 启动命令,如不设置directory则必须写绝对路径
autostart = true ; 在 supervisord 启动的时候也自动启动
startsecs = 5 ; 启动 5 秒后没有异常退出,就当作已经正常启动了
autorestart = true ; 程序异常退出后自动重启
startretries = 3 ; 启动失败自动重试次数,默认是 3
user = python ; 用哪个用户启动
redirect_stderr = true ; 把 stderr 重定向到 stdout,默认 false
stdout_logfile_maxbytes = 20MB ; stdout 日志文件大小,默认 50MB
stdout_logfile_backups = 20 ; stdout 日志文件备份数
; stdout 日志文件,需要注意当指定目录不存在时无法正常启动,所以需要手动创建目录(supervisord 会自动创建日志文件)
stdout_logfile = /data/logs/aiohhttp.log
8,supervisor启动异常-SPWAN ERROR:
绝大多数是日志目录或者日志文件再或者就是supervisor.log和supervisor.sock文件的读取权限导致的,例如用root用户启动supervisord时,创建的/tmp/supervisor.log和/tmp/supervisor.sock文件,杀掉supervisor后用其他用户无法正常启动,经查询发现这两个文件的权限属组用户其他用户都没有写权限,这时候删掉文件或更改授权后可正常启动supervisor
---------------------
作者:踏雪追风
来源:优快云
原文:https://blog.youkuaiyun.com/u010080628/article/details/79786495
版权声明:本文为博主原创文章,转载请附上博文链接!