1.1 supervisor介绍
1、什么是supervisor
1. Supervisor是用Python开发的一个client/server服务,是Linux/Unix系统下的一个进程管理工具,不支持Windows系统。、
2. 作用:它可以很方便的监听、启动、停止、重启一个或多个进程。
3. 用Supervisor管理的进程,当一个进程意外被杀死,supervisort监听到进程死后,会自动将它重新拉起
4. 很方便的做到进程自动恢复的功能,不再需要自己写shell脚本来控制。
5. 说白了,它真正有用的功能是俩个将非daemon(守护进程)程序变成deamon方式运行对程序进行监控,当程序退出时,可以自动拉起程序。
6. 但是它无法控制本身就是daemon的服务。
2、supervisor安装与基本使用
1)supervisor安装
[root@linux-node4 aaa]# yum install -y supervisor # 使用yum安装supervisor,安装完成与两个重要文件
/etc/supervisord.conf # supervisor配置文件
/etc/supervisord.d/ # 子进程配置文件路径
[root@linux-node4 aaa]# vim /etc/supervisord.conf # 配置supervisor主配置文件
[inet_http_server] ; HTTP服务器,提供web管理界面
port=*:9001 ; Web管理后台运行的IP和端口,如果开放到公网,需要注意安全性
username=user ; 登录管理后台的用户名
password=123 ; 登录管理后台的用户名
2)配置测试进程(/etc/supervisor.d/)
1)子进程配置文件:需要管理的子进程都可放到这个文件夹里
[root@linux-node4 aaa]# vim /etc/supervisord.d/test.ini
[program:test] ; 项目名
directory=/tmp/ ; 脚本路径
command =uwsgi --ini test.ini ; 启动命令,可以看出与手动在命令行启动的命令是一样的
autostart = false ; 在 supervisord 启动的时候也自动启动
user=root ; 脚本运行的用户身份
startsecs = 5 ; 启动 5 秒后没有异常退出,就当作已经正常启动了
startretries = 3 ; 启动失败自动重试次数,默认是 3
autorestart = true ; 程序异常退出后自动重启
redirect_stderr = true ; 把 stderr 重定向到 stdout,默认 false
stdout_logfile_maxbytes = 20MB ; stdout 日志文件大小,默认 50MB
stdout_logfile = /root/js_back_uwsgi.log ; 日志输出位置
stderr_logfile = /root/js_back_err.log
2)测试脚本
[root@linux-node4 aaa]# vim /tmp/test.ini
[uwsgi]
chdir = /tmp
module = test.wsgi
master = true
processes = 3
socket = 0.0.0.0:8002
vacuum = true
pythonpath = /usr/bin/python3
pidfile = /tmp/js_back.pid
#注释掉daemonize模式,因为Supervisor无法控制守护进程服务
#daemonize = /root/js_back/uwsgi.log
3)演示使用supervisor管理程序
[root@linux-node1 supervisord.d]# supervisord -c /etc/supervisord.conf # 启动supervisor
[root@linux-node1 supervisord.d]# ps -ef | grep supervisor # 查看supervisor是否允许
[root@linux-node1 tmp]# supervisorctl status # 查看supervisor管理的所有进程状态
[root@linux-node1 supervisord.d]# supervisorctl restart test # 启动test程序
[root@linux-node1 supervisord.d]# supervisorctl stop all # 停止所有程序
4)supervisor常用命令
[root@linux-node1 tmp]# supervisorctl status # 查看supervisor管理所有进程的状态
[root@linux-node1 tmp]# supervisorctl stop es # 停止名称es程序(如果停止所有换成all)
[root@linux-node1 tmp]# supervisorctl start es # 启动项目名称es程序
[root@linux-node1 tmp]# supervisorctl restart # 重启项目名称es程序
[root@linux-node1 tmp]# supervisorctl update # 配置文件修改后使用该命令加载新的配置
[root@linux-node1 tmp]# supervisorctl reload # 重新启动配置中的所有程序
3、在页面访问
111111111111111