安装配置supervisor

来源:互联网 发布:java超时处理 编辑:程序博客网 时间:2024/06/05 17:28
  1. 使用pip安装supervisor
pip install supervisor
  1. 创建配置文件
echo_supervisord_conf > /etc/supervisord.conf
  1. 配置
    取消如下行的注释
[inet_http_server]           ; inet (TCP) server disabled by defaultport=9001                    ; (ip_address:port specifier, *:port for all iface)username=admin               ; (default is no username (open server))password=handhand            ; (default is no password (open server))

这里配置的是supervisor的远程控制端口和用户
在文件末尾修改或添加如下内容

[include]files = /etc/supervisord.d/*.conf

创建/etc/supervisord.d/,里面是我们个性化的配置
4. 配置被管理应用
在/etc/supervisord.d/创建tomcat.conf,这个文件用来存放被管理的tomcat的相关配置,具体配置参考一下内容

;[program:theprogramname]      ;这个就是咱们要管理的子进程了,":"后面的是名字,最好别乱写和实际进程                                有点关联最好。这样的program我们可以设置一个或多个,一个program就是                                要被管理的一个进程;command=/bin/cat              ; 这个就是我们的要启动进程的命令路径了,可以带参数                                例子:/home/test.py -a 'hehe'                                有一点需要注意的是,我们的command只能是那种在终端运行的进程,不能是                                守护进程。这个想想也知道了,比如说command=service httpd start                                httpd这个进程被linux的service管理了,我们的supervisor再去启动这个命令                                这已经不是严格意义的子进程了。                                这个是个必须设置的项;process_name=%(program_name)s ; 这个是进程名,如果我们下面的numprocs参数为1的话,就不用管这个参数                                 了,它默认值%(program_name)s也就是上面的那个program冒号后面的名字,                                 但是如果numprocs为多个的话,那就不能这么干了。想想也知道,不可能每个                                 进程都用同一个进程名吧。;numprocs=1                    ; 启动进程的数目。当不为1时,就是进程池的概念,注意process_name的设置                                 默认为1    。。非必须设置;directory=/tmp                ; 进程运行前,会前切换到这个目录                                 默认不设置。。。非必须设置;umask=022                     ; 进程掩码,默认none,非必须;priority=999                  ; 子进程启动关闭优先级,优先级低的,最先启动,关闭的时候最后关闭                                 默认值为999 。。非必须设置;autostart=true                ; 如果是true的话,子进程将在supervisord启动后被自动启动                                 默认就是true   。。非必须设置;autorestart=unexpected        ; 这个是设置子进程挂掉后自动重启的情况,有三个选项,false,unexpected                                 和true。如果为false的时候,无论什么情况下,都不会被重新启动,                                 如果为unexpected,只有当进程的退出码不在下面的exitcodes里面定义的退                                  出码的时候,才会被自动重启。当为true的时候,只要子进程挂掉,将会被无                                 条件的重启;startsecs=1                   ; 这个选项是子进程启动多少秒之后,此时状态如果是running,则我们认为启                                 动成功了                                 默认值为1 。。非必须设置;startretries=3                ; 当进程启动失败后,最大尝试启动的次数。。当超过3次后,supervisor将把                                 此进程的状态置为FAIL                                 默认值为3 。。非必须设置;exitcodes=0,2                 ; 注意和上面的的autorestart=unexpected对应。。exitcodes里面的定义的                                 退出码是expected的。;stopsignal=QUIT               ; 进程停止信号,可以为TERM, HUP, INT, QUIT, KILL, USR1, or USR2等信号                                  默认为TERM 。。当用设定的信号去干掉进程,退出码会被认为是expected                                  非必须设置;stopwaitsecs=10               ; 这个是当我们向子进程发送stopsignal信号后,到系统返回信息                                 给supervisord,所等待的最大时间。 超过这个时间,supervisord会向该                                 子进程发送一个强制kill的信号。                                 默认为10秒。。非必须设置;stopasgroup=false             ; 这个东西主要用于,supervisord管理的子进程,这个子进程本身还有                                 子进程。那么我们如果仅仅干掉supervisord的子进程的话,子进程的子进程                                 有可能会变成孤儿进程。所以咱们可以设置可个选项,把整个该子进程的                                 整个进程组都干掉。 设置为true的话,一般killasgroup也会被设置为true。                                 需要注意的是,该选项发送的是stop信号                                 默认为false。。非必须设置。。;killasgroup=false             ; 这个和上面的stopasgroup类似,不过发送的是kill信号;user=chrism                   ; 如果supervisord是root启动,我们在这里设置这个非root用户,可以用来                                 管理该program                                 默认不设置。。。非必须设置项;redirect_stderr=true          ; 如果为true,则stderr的日志会被写入stdout日志文件中                                 默认为false,非必须设置;stdout_logfile=/a/path        ; 子进程的stdout的日志路径,可以指定路径,AUTO,none等三个选项。                                 设置为none的话,将没有日志产生。设置为AUTO的话,将随机找一个地方                                 生成日志文件,而且当supervisord重新启动的时候,以前的日志文件会被                                 清空。当 redirect_stderr=true的时候,sterr也会写进这个日志文件;stdout_logfile_maxbytes=1MB   ; 日志文件最大大小,和[supervisord]中定义的一样。默认为50;stdout_logfile_backups=10     ; 和[supervisord]定义的一样。默认10;stdout_capture_maxbytes=1MB   ; 这个东西是设定capture管道的大小,当值不为0的时候,子进程可以从stdout                                 发送信息,而supervisor可以根据信息,发送相应的event。                                 默认为0,为0的时候表达关闭管道。。。非必须项;stdout_events_enabled=false   ; 当设置为ture的时候,当子进程由stdout向文件描述符中写日志的时候,将                                 触发supervisord发送PROCESS_LOG_STDOUT类型的event                                 默认为false。。。非必须设置;stderr_logfile=/a/path        ; 这个东西是设置stderr写的日志路径,当redirect_stderr=true。这个就不用                                 设置了,设置了也是白搭。因为它会被写入stdout_logfile的同一个文件中                                 默认为AUTO,也就是随便找个地存,supervisord重启被清空。。非必须设置;stderr_logfile_maxbytes=1MB   ; 这个出现好几次了,就不重复了;stderr_logfile_backups=10     ; 这个也是;stderr_capture_maxbytes=1MB   ; 这个一样,和stdout_capture一样。 默认为0,关闭状态;stderr_events_enabled=false   ; 这个也是一样,默认为false;environment=A="1",B="2"       ; 这个是该子进程的环境变量,和别的子进程是不共享的;serverurl=AUTO                ; ;[group:thegroupname]  ;这个东西就是给programs分组,划分到组里面的program。我们就不用一个一个去操作了                         我们可以对组名进行统一的操作。 注意:program被划分到组里面之后,就相当于原来                         的配置从supervisor的配置文件里消失了。。。supervisor只会对组进行管理,而不再                         会对组里面的单个program进行管理了;programs=progname1,progname2  ; 组成员,用逗号分开                                 这个是个必须的设置项;priority=999                  ; 优先级,相对于组和组之间说的                                 默认999。。非必须选项
  1. 启动supervisor
supervisord -c /etc/supervisord.conf

supervisorctl 的所有参数如下:

status 查看所有的进程状态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
0 0
原创粉丝点击