zoukankan      html  css  js  c++  java
  • supervisor 使用tips

    Supervisor (http://supervisord.org) 是一个用 Python 写的进程管理工具,可以很方便的用来启动、重启、关闭进程,supervisor可以同时监控多个进程,并可以在进程死亡时自动重新拉起。

    在supervisor使用过程中也会遇到一些问题,这里对遇到的问题进行记录:

    1.supervisor监控的进程需要重启自己,并且调用supervisor的命令进行重启。

    例如子进程的名字叫做testProcess,在testProcess进程中通过如下命令进行重启

    /usr/bin/supervisorctl restart testProcess

    ,这种情况下你可能会发现进程aics停止了,但是没有重启。

    观察进程配置,可以看到stopasgroup这个配置项。实际测试,这个配置项开启状态(默认开启)下,监控进程创建的子进程也会纳入stop监控,此时如果调用supervisor的命令导致进程停止,那么进程的子进程也会被停止。猜测

    /usr/bin/supervisorctl restart testProcess 的命令是先调用stop,stop之后再调用start,但是stop时由于自己本身是监控进程的子进程,因此也会被停止,start的部分根本执行不到。
    ; [program:testProcess]是被管理的进程配置参数,testProcess是进程的名称
    [program:testProcess]
    command=/opt/tomca/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/tomcat/logs/catalina.out
    stopasgroup=false     ;默认为false,进程被杀死时,是否向这个进程组发送stop信号,包括子进程
    killasgroup=false     ;默认为false,向进程组发送kill信号,包括子进程

    因此这种情况下要达到目的可以采用如下方法:

    a.将stopasgroup的配置修改为false,不过这个需要考虑进程业务上是否会产生其他子进程,在进程死亡时,子进程是否需要停止

    b.将调用命令改为 /usr/bin/supervisorctl reload,这样是重新加载配置并且重启所有监控进程,如果一个supervisor监控了多个进程,那么不建议这么做

    c.借助第三方进程,由监控进程组内的进程来完成,只需给其发送消息即可

  • 相关阅读:
    THINKPHP3.2视频教程
    PHPCMS 学习
    PHPCMS 后台学习
    phpcms 模板学习
    二叉树的创建与遍历(链式存储)
    MySQL基础~~增、删、改、简单查
    队列的基本操作(链队列)
    MySQL基础~~表结构操作
    行编辑程序
    循环链表的基本操作
  • 原文地址:https://www.cnblogs.com/lmsthoughts/p/8475535.html
Copyright © 2011-2022 走看看