Supervisor是用Python开发的一套通用的进程管理程序,能将一个普通的命令行进程变为后台daemon,并监控进程状态,异常退出时能自动重启。它是通过fork/exec的方式把这些被管理的进程当作supervisor的子进程来启动,这样只要在supervisor的配置文件中,把要管理的进程的可执行文件的路径写进去即可。也实现当子进程挂掉的时候,父进程可以准确获取子进程挂掉的信息的,可以选择是否自己启动和报警。supervisor还提供了一个功能,可以为supervisord或者每个子进程,设置一个非root的user,这个user就可以管理它对应的进程
[root@Master ~]# cat /etc/redhat-release
CentOS Linux release 7.2.1511 (Core)
yum install supervisor -y
打印示例内容到终端
echo_supervisord_conf
生成配置文件
echo_supervisord_conf > /etc/supervisord.conf
常用配置介绍
字段名称 | 注释 |
---|---|
port=127.0.0.1:9001 | 管理网站端口 |
username=user | 管理网站用户名 |
password=123 | 管理网站密码 |
files = relative/directory/*.ini | 配置文件存放目录及格式 |
启动
supervisord -c /etc/supervisord.conf
加入自启动
systemctl enable supervisord
服务信息查看
[root@Master src]# ps -ef|grep supervisor
root 29019 1 0 14:42 ? 00:00:00 /usr/bin/python /usr/bin/supervisord -c /etc/supervisord.conf
root 29110 8863 0 14:43 pts/1 00:00:00 grep --color=auto supervisor
停止supervisor
[root@Master src]# supervisorctl shutdown
Shut down
重新加载
[root@Master src]# supervisorctl reload
Restarted supervisord
新建配置文件目录,最下面的配置路径,默认为
files = relative/directory/*.ini
可更改
files = /etc/supervisor/*.ini
mkdir -p /etc/supervisor/
在/etc/supervisor/
新建nginx.ini
vim /etc/supervisor/nginx.ini
#-----------------------------------
[program: nginx]
command=/app/nginx/sbin/nginx -g 'daemon off;' # 修改自己的路径
autorestart=true ;
autostart=true ;
stderr_logfile=/app/nginx/logs/error.log ; #这是nginx日志路径,web会用到
stdout_logfile=/app/nginx/logs/stdout.log ;
environment=ASPNETCORE_ENVIRONMENT=Production ;
user=root ; #启动用户
stopsignal=INT
startsecs=10 ;
startretries=5 ;
stopasgroup=true
重启supervisor
[root@Master etc]# supervisorctl -c /etc/supervisord.conf reload
Restarted supervisord
发现如下报错
Error: The directory named as part of the path /app/nginx/logs/stdout.log does not exist in section 'program: nginx' (file: '/etc/supervisor/nginx.ini')
For help, use /usr/bin/supervisord -h
这个错误的原因是日志不存在,手动创建即可
mkdir -p /app/nginx/logs
再次重启,发现启动成功
查看nginx进程
[root@Master supervisor]# ps -ef|grep nginx
root 2154 2153 0 15:42 ? 00:00:00 nginx: master process /app/nginx/sbin/nginx -g daemon off;
使用supervisor查看nginx信息
[root@Master supervisor]# supervisorctl status
nginx RUNNING pid 2154, uptime 0:02:40
使用supervisor关闭nginx
[root@Master supervisor]# supervisorctl stop nginx
nginx: stopped
再次查看
[root@Master supervisor]# supervisorctl status
nginx STOPPED Jul 20 03:45 PM
supervisor启动nginx
[root@Master supervisor]# supervisorctl start nginx
nginx: started
[root@Master supervisor]# supervisorctl status
nginx RUNNING pid 2322, uptime 0:00:13
手动关闭nginx进程,看supervisor是否会拉起
[root@Master supervisor]# pkill nginx
[root@Master supervisor]# ps -ef|grep nginx
root 2405 2153 0 15:48 ? 00:00:00 nginx: master process /app/nginx/sbin/nginx -g daemon off;
root 2406 2405 0 15:48 ? 00:00:00 nginx: worker process
拉起成功
修改/etc/supervisord.conf
,打开以下几行注释
22 [inet_http_server] ; inet (TCP) server disabled by default
23 port=192.168.180.XXX:9001 ; ip_address:port specifier, *:port for all iface
24 username=user ; default is no username (open server)
25 password=123 ; default is no password (open server)
浏览器访问验证http://192.168.180.XXX:9001/
即可通过浏览器对nginx进行操作,以及查看日志等,到此就全部完成了。
码字不易,请多多点赞