supervisor使用详解

发布时间 2023-05-25 16:17:59作者: huningfei

一 介绍

使用文档:http://supervisord.org/
supervisor是Python开发的c/s服务,是Linux系统下的进程管理工具。
可以监听、启动、停止、重启一个或多个进程
用supervisor管理的进程,当一个进程意外被杀死,supervisor监听到进程死后,会自动将它重启,很方便的做到进程的自动恢复的功能,不在需要自己写脚本来控制

二 安装

2.1 pip安装

# pip install supervisor

#生成配置文件
sudo mkdir /etc/supervisor
# echo_supervisord_conf > /etc/supervisor/supervisord.conf

2.2 使用yum进行安装

# yum install -y epel-release
# yum install -y supervisor

三 配置文件

使用yum安装的supervisor会在/etc/会生成一个supervisor.conf文件及一个supervisor.d文件目录

3.1 主配置文件

[root@test-Server1 supervisord.d]# grep -v "^;" /etc/supervisord.conf |grep -v "^$"
[unix_http_server]
file=/run/supervisor/supervisor.sock   ; (the path to the socket file)
[inet_http_server]         ; inet (TCP) server disabled by default
port=127.0.0.1:9001        ; (ip_address:port specifier, *:port for all iface)
username=user              ; (default is no username (open server))
password=123abc             ; (default is no password (open server))
[supervisord]
logfile=/var/log/supervisor/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=/run/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:///run/supervisor/supervisor.sock ; use a unix:// URL  for a unix socket
[include]
files = supervisord.d/*.conf

3.2 配置子配置文件用于监控各个进程

[root@test-Server1 supervisord.d]# cat supervisor_java_one.conf
[program:thrk_erp]
command=/usr/local/java/bin/java -jar /www/wwwroot/renkang-erp/thrk_erp-1.0-SNAPSHOT.jar  --server.port=9527 --spring.profiles.active=self >> /mnt/xinceshi/erp.log
priority=1                    ; 数字越高,优先级越高
numprocs=1                    ; 启动几个进程
autostart=true                ; 随着supervisord的启动而启动
autorestart=true              ; 自动重启
startretries=10               ; 启动失败时的最多重试次数
exitcodes=0                   ; 正常退出代码
stopsignal=KILL               ; 用来杀死进程的信号
stopwaitsecs=10               ; 发送SIGKILL前的等待时间
redirect_stderr=true          ; 重定向stderr到stdout

[program:userservice]
command=/usr/local/java/bin/java -jar  /www/wwwroot/renkang-state/usersevice-1.0-SNAPSHOT.jar --server.port=19999 --spring.profiles.active=self 
priority=1                    ; 数字越高,优先级越高
numprocs=1                    ; 启动几个进程
autostart=false               ; true随着supervisord的启动而启动,即使进程存在,它也会重新启动一个,false就不会重新启动了
autorestart=true              ; 自动重启
startretries=10               ; 启动失败时的最多重试次数
exitcodes=0                   ; 正常退出代码
stopsignal=KILL               ; 用来杀死进程的信号
stopwaitsecs=10               ; 发送SIGKILL前的等待时间
redirect_stderr=true          ; 重定向stderr到stdout


四 启动supervisord

 supervisord -c /etc/supervisord.conf
 systemctl start supervisord.service 

五 supervisor常用命令

supervisorctl status   # 查看进程运行状态
supervisorctl start weather   # 启动进程
supervisorctl stop weather    # 关闭进程
supervisorctl restart weather   # 重启进程
supervisorctl update    # 重新载入配置文件
supervisorctl shutdown    # 关闭 supervisord
supervisorctl clear weather    # 清空进程日志
supervisorctl stop restart + all    # 表示启动,关闭,重启所有进程。

我想启动上面配置好的任务就是supervisorctl start userservice

image