美文网首页
Linux下的进程控制系统————Supervisor

Linux下的进程控制系统————Supervisor

作者: EarthChen | 来源:发表于2017-08-06 18:15 被阅读200次

    我们在部署网站或者在ssh到服务器上去进行一些长时间操作的任务时候,通常不喜欢长时间开启终端在其中等待,尤其是Windows下putty这类软件,长时间不操作就会结束,尴尬的是,我们跑的进程也会直接终端,为了解决这个问题,我们需要把进程扔到后台,让他自己运行

    在这里我们介绍一个名叫Supervisor的进程控制系统,
    它是一个C/S系统(注意: 其提供WEB接口给用户查询和控制), 它允许用户去监控和控制在类UNIX系统的进程. 它的目标与launchd, daemontools和runit有些相似, 但是与它们不一样的是, 它不是作为init(进程号pid是1)运行. 它是被用来控制进程, 并且它在启动的时候和一般程序并无二致
    supervisor是一个制作守护进程的工具,用户可以在UNIX系统中监控、管理进程。常用于管理与某个用户或项目相关的进程。去帮我们维护各种服务器的进程,即使有软件崩了也能帮我们自动重启

    Supervisor


    首先先把官网丢上来http://supervisord.org/

    安装

    两种方式去安装

    1. 直接使用apt包管理安装
    $ sudo apt-get install supervisor
    
    1. 通过pip安装
    $ sudo pip install supervisor
    

    安装成功后,supervisor就会默认启动

    使用说明

    很多地方都有不同的使用方式,个人比较倾向把每个进程的文件单独拆分放在/etc/supervisor/conf.d/目录下,以conf为扩展名
    这里以我自己的一个项目的进程作为例子(进程名为x508server)

    1. 创建并编写x508server.conf
    [program:x508server]
    command=python /home/webserver/web/WebServer/manage.py runserver 0.0.0.0:8000 ; 被监控的进程路径
    numprocs=1                    ; 启动几个进程
    directory=/home/webserver/web/WebServer/               ; 执行前要不要先cd到目录去,一般不用
    autostart=true                ; 随着supervisord的启动而启动
    autorestart=true              ; 自动重启。。当然要选上了
    startretries=10               ; 启动失败时的最多重试次数
    exitcodes=0                   ; 正常退出代码
    stopsignal=KILL               ; 用来杀死进程的信号
    stopwaitsecs=10               ; 发送SIGKILL前的等待时间
    redirect_stderr=true          ; 重定向stderr到stdout
    stdout_logfile=logfile        ; 指定日志文件
    ; 默认为 false,如果设置为 true,当进程收到 stop 信号时,会自动将该信号发给该进程的子进程。如果这个配置项为 true,那么也隐含 killasgroup 为 true。例如在 Debug 模式使用 Flask 时,Flask 不会将接收到的 stop 信号也传递给它的子进程,因此就需要设置这个配置项。
    stopasgroup=true             ; send stop signal to the UNIX process 
    ; 默认为 false,如果设置为 true,当进程收到 kill 信号时,会自动将该信号发给该进程的子进程。如果这个程序使用了 python 的 multiprocessing 时,就能自动停止它的子线程。
    killasgroup=true             ; SIGKILL the UNIX process group (def false
    
    
    1. 让supervisor重新加载配置文件,然后启动x508server进程
    $ supervisorctl reload
    $ supervisorctl start x508server
    
    1. 结束指定进程
    $ supervisorctl x508serevr stop
    
    

    常用命令

    1. 启动某个进程
    $ supervisorctl start x508serevr 
    
    
    1. 关闭某个进程
    $ supervisorctl stop x508serevr 
    
    
    1. 停止全部进程,注:start、restart、stop都不会载入最新的配置文件
    $ supervisorctl stop all
    
    1. 载入最新的配置文件,停止原有进程并按新的配置启动、管理所有进程
    $ supervisorctl reload
    
    1. 根据最新的配置文件,启动新配置或有改动的进程,配置没有改动的进程不会受影响而重启
    $ supervisorctl update
    
    1. 启动supervisord
    $ sudo supervisord -c /etc/supervisor/supervisord.conf 
    

    配置说明

    1. 每个进程的配置
    ;*为必须填写项
    ;*[program:应用名称]
    [program:cat]
    
    ;*命令路径,如果使用python启动的程序应该为 python /home/test.py, 
    ;不建议放入/home/user/, 对于非user用户一般情况下是不能访问
    command=/bin/cat
    
    ;当numprocs为1时,process_name=%(program_name)s
    ;当numprocs>=2时,%(program_name)s_%(process_num)02d
    process_name=%(program_name)s
    
    ;进程数量
    numprocs=1
    
    ;执行目录,若有/home/supervisor_test/test1.py
    ;将directory设置成/home/supervisor_test
    ;则command只需设置成python test1.py
    ;否则command必须设置成绝对执行目录
    directory=/tmp
    
    ;掩码:--- -w- -w-, 转换后rwx r-x w-x
    umask=022
    
    ;优先级,值越高,最后启动,最先被关闭,默认值999
    priority=999
    
    ;如果是true,当supervisor启动时,程序将会自动启动
    autostart=true
    
    ;*自动重启
    autorestart=true
    
    ;启动延时执行,默认1秒
    startsecs=10
    
    ;启动尝试次数,默认3次
    startretries=3
    
    ;当退出码是0,2时,执行重启,默认值0,2
    exitcodes=0,2
    
    ;停止信号,默认TERM
    ;中断:INT(类似于Ctrl+C)(kill -INT pid),退出后会将写文件或日志(推荐)
    ;终止:TERM(kill -TERM pid)
    ;挂起:HUP(kill -HUP pid),注意与Ctrl+Z/kill -stop pid不同
    ;从容停止:QUIT(kill -QUIT pid)
    ;KILL, USR1, USR2其他见命令(kill -l),说明1
    stopsignal=TERM
    
    stopwaitsecs=10
    
    ;*以root用户执行
    user=root
    
    ;重定向
    redirect_stderr=false
    
    stdout_logfile=/a/path
    stdout_logfile_maxbytes=1MB
    stdout_logfile_backups=10
    stdout_capture_maxbytes=1MB
    stderr_logfile=/a/path
    stderr_logfile_maxbytes=1MB
    stderr_logfile_backups=10
    stderr_capture_maxbytes=1MB
    
    ;环境变量设置
    environment=A="1",B="2"
    
    serverurl=AUTO
    
    1. (inet_http_server)配置说明
    [inet_http_server]         ; inet (TCP) server disabled by default
    port=0.0.0.0:9001          ; (ip_address:port specifier, *:port for all iface)
    username=user              ; 用户名 (default is no username (open server))
    password=123               ; 密码 (default is no password (open server))
    

    注:

    • 上述环境在ubuntu16.04 lts中测试成功
    • 上述文字皆为个人看法,如有错误或建议请及时联系我

    相关文章

      网友评论

          本文标题:Linux下的进程控制系统————Supervisor

          本文链接:https://www.haomeiwen.com/subject/hxlnlxtx.html