Supervisor是基于 Python 的进程管理工具,能够帮助咱们更简单的启动、重启和中止服务器上的后台进程,是 Linux 服务器管理的效率工具。web
什么状况下咱们须要进程管理呢?就是执行一些须要以守护进程方式启动的程序,好比一个后台任务、一组 Web 服务的进程(说是一组,是由于常常用 Nginx 来作负载均衡),这些极可能是一些网站、REST API 的服务、消息推送的后台服务、日志数据的处理分析服务等等。apache
博主用的是ubuntu系统,网上好多Supervisor安装方法,但仍是感受最好用的仍是apt-getubuntu
apt-get install supervisor
supervisor安装完成后会生成三个执行程序:supervisortd、supervisorctl、echo_supervisord_conf,分别是supervisor的守护进程服务(用于接收进程管理命令)、客户端(用于和守护进程通讯,发送管理进程的指令)、生成初始配置文件程序。vim
supervisortd默认配置位置为
/etc/supervisor/supervisord.conftomcat
能够经过运行echo_supervisord_conf程序生成supervisor的初始化配置文件,自带的配置文件内容不全,建议从新初始化,以下所示:安全
echo_supervisord_conf > /etc/supervisor/supervisord.conf
supervisor的配置参数较多,下面介绍一下经常使用的参数配置,详细的配置及说明,请参考官方文档
注:“;”开头表示注释服务器
[unix_http_server] file=/tmp/supervisor.sock ;UNIX socket 文件,supervisorctl 会使用 ;chmod=0700 ;socket文件的mode,默认是0700 ;chown=nobody:nogroup ;socket文件的owner,格式:uid:gid ;[inet_http_server] ;HTTP服务器,提供web管理界面 ;port=127.0.0.1:9001 ;Web管理后台运行的IP和端口,若是开放到公网,须要注意安全性 ;username=user ;登陆管理后台的用户名 ;password=123 ;登陆管理后台的密码 [supervisord] logfile=/tmp/supervisord.log ;日志文件,默认是 $CWD/supervisord.log logfile_maxbytes=50MB ;日志文件大小,超出会rotate,默认 50MB,若是设成0,表示不限制大小 logfile_backups=10 ;日志文件保留备份数量默认10,设为0表示不备份 loglevel=info ;日志级别,默认info,其它: debug,warn,trace pidfile=/tmp/supervisord.pid ;pid 文件 nodaemon=false ;是否在前台启动,默认是false,即以 daemon 的方式启动 minfds=1024 ;能够打开的文件描述符的最小值,默认 1024 minprocs=200 ;能够打开的进程数的最小值,默认 200 [supervisorctl] serverurl=unix:///tmp/supervisor.sock ;经过UNIX socket链接supervisord,路径与unix_http_server部分的file一致 ;serverurl=http://127.0.0.1:9001 ; 经过HTTP的方式链接supervisord ; [program:xx]是被管理的进程配置参数,xx是进程的名称 [program:xx] command=/opt/apache-tomcat-8.0.35/bin/catalina.sh run ; 程序启动命令 autostart=true ; 在supervisord启动的时候也自动启动 startsecs=10 ; 启动10秒后没有异常退出,就表示进程正常启动了,默认为1秒 autorestart=true ; 程序退出后自动重启,可选值:[unexpected,true,false],默认为unexpected,表示进程意外杀死后才重启 startretries=3 ; 启动失败自动重试次数,默认是3 user=tomcat ; 用哪一个用户启动进程,默认是root priority=999 ; 进程启动优先级,默认999,值小的优先启动 redirect_stderr=true ; 把stderr重定向到stdout,默认false stdout_logfile_maxbytes=20MB ; stdout 日志文件大小,默认50MB stdout_logfile_backups = 20 ; stdout 日志文件备份数,默认是10 ; stdout 日志文件,须要注意当指定目录不存在时没法正常启动,因此须要手动建立目录(supervisord 会自动建立日志文件) stdout_logfile=/opt/apache-tomcat-8.0.35/logs/catalina.out stopasgroup=false ;默认为false,进程被杀死时,是否向这个进程组发送stop信号,包括子进程 killasgroup=false ;默认为false,向进程组发送kill信号,包括子进程 ;包含其它配置文件 [include] files = relative/directory/*.ini ;能够指定一个或多个以.ini结束的配置文件
注:建议[progream:xx]写在专门的一个文件夹下,不将全部新增配置信息全写在一个配置文件里,每一个程序设置一个配置文件,相互隔离。
安装supervisor会自带一个文件夹/etc/supervisor/conf.d/
因此能够在配置文件中添加负载均衡
[include] files = /etc/supervisor/config.d/*.conf
这里添加一个tomcat的progream的配置,做为一个进程演示socket
vim /etc/supervisor/cofig.d/tomcat.conf
[program:tomcat] command=/home/tomcat8.0/bin/catalina.sh run stdout_logfile=/home/tomcat8.0/logs/catalina.out autostart=true autorestart=true startsecs=5 priority=1 stopasgroup=true killasgroup=true
supervisord -c /etc/supervisor/supervisord.conf
supervisord启动成功后,能够经过supervisorctl命令进入,控制进程,启动、中止、重启。
运行supervisorctl命令,不加参数,会进入supervisor客户端的交互终端,并会列出当前所管理的全部进程。工具
supervisorctl
进入后的命令有以下:
update 更新新的配置到supervisord(不会重启原来已运行的程序) reload,载入全部配置文件,并按新的配置启动、管理全部进程(会重启原来已运行的程序) start xxx: 启动某个进程 restart xxx: 重启某个进程 stop xxx: 中止某一个进程(xxx),xxx为[program:theprogramname]里配置的值 stop groupworker: 重启全部属于名为groupworker这个分组的进程(start,restart同理) stop all,中止所有进程,注:start、restart、stop都不会载入最新的配置文 reread,当一个服务由自动启动修改成手动启动时执行一下就ok