Supervisor安装配置及常见故障

1,版本要求:

    ≥python2.4 & 2,安装命令:

    sudo pip install supervisor

3,配置:
    mkdir /etc/supervisor
    echo_supervisord_conf > /etc/supervisor/supervisord.conf

4,program配置:
    为方便各个app单独维护,我自己创建了apps目录来存储各个app的配置
        cd /etc/supervisor
    mkdir apps
    然后编辑/etc/supervisor/supervisord.conf,修改include配置项:
        [include]
        files = /etc/supervisor/apps/*.conf

5,启动:

    用-c参数来指定supervisord.conf的参数:

    supervisord -c /etc/supervisor/supervisord.conf

6,管理:
    # 读取有更新(增加)的配置文件,不会启动新添加的程序
    $ supervisorctl reread
    # 重启配置文件修改过的程序
    $ supervisorctl update
    # 查看程序状态
    $ supervisorctl status
    # 启动程序 App_name
    $ supervisorctl start App_name
    # 关闭程序 App_name
    $ supervisorctl stop App_name
    # 重启程序 App_name
    $ supervisorctl restart App_name

    也可以单独执行supervisorctl,然后输入不同的命令


7,program各个常用参数:
    [program:appname]    ;appname配置项
    directory = /path/to/excute/command     ; 在哪个目录下执行命令
    command = python run.py runserver -h 0.0.0.0 -p 80      ; 启动命令,如不设置directory则必须写绝对路径
    autostart = true     ; 在 supervisord 启动的时候也自动启动
    startsecs = 5        ; 启动 5 秒后没有异常退出,就当作已经正常启动了
    autorestart = true   ; 程序异常退出后自动重启
    startretries = 3     ; 启动失败自动重试次数,默认是 3
    user = python          ; 用哪个用户启动
    redirect_stderr = true      ; 把 stderr 重定向到 stdout,默认 false
    stdout_logfile_maxbytes = 20MB      ; stdout 日志文件大小,默认 50MB
    stdout_logfile_backups = 20     ; stdout 日志文件备份数
    ; stdout 日志文件,需要注意当指定目录不存在时无法正常启动,所以需要手动创建目录(supervisord 会自动创建日志文件)

    stdout_logfile = /data/logs/aiohhttp.log


8,supervisor启动异常-SPWAN ERROR:

绝大多数是日志目录或者日志文件再或者就是supervisor.log和supervisor.sock文件的读取权限导致的,例如用root用户启动supervisord时,创建的/tmp/supervisor.log和/tmp/supervisor.sock文件,杀掉supervisor后用其他用户无法正常启动,经查询发现这两个文件的权限属组用户其他用户都没有写权限,这时候删掉文件或更改授权后可正常启动supervisor

你可能感兴趣的:(Ptyhon,supervisor)