zoukankan      html  css  js  c++  java
  • supervisor

    安装supervisor

    链接:https://pan.baidu.com/s/11usRPxYY_nDzKflvrxRp2A
    提取码:7bce

    1、cd /home/webContainer/
     
    2、mkdir supervisor
     
    3、cd supervisor/,上传supervisor-3.3.5.tar.gz, meld3-1.0.2.tar.gz, setuptools-0.6c11.tar.gz
     
    4、解压 tar –zxvf setuptools-0.6c11.tar.gz 等其他文件
     
    5、cd setuptools-0.6c11,执行命令python setup.py build && python setup.py install
     
    6、cd ../meld3-1.0.2,        执行python setup.py install
    
    7、cd ../supervisor-3.3.5,    执行python setup.py install
     
    8、验证supervisor安装是否成功  

    配置supervisor

    1、在/home/webContainer/supervisor/supervisor-3.3.5 目录下执行mkdir supervisord.d,创建supervisord.d目录
     
    2、echo_supervisord_conf > supervisord.conf,生成supervisord.conf
     
    3、vim supervisord.conf修改配置文件supervisord.conf
     
    4、cd supervisord.d/,创建服务相关配置,建议一个服务创建一个配置,vim supervisor_pntmss-web.conf,配置tomcat监控服务
     
    5、supervisord -c supervisord.conf,启动supervisor服务
    
    6、使用supervisorctl status或http://145.13.38.16:9001查看启动服务列表

     开机启动

    1、cd /usr/lib/systemd/system,创建supervisord.service文件,执行vim supervisord.service

    2、设置开机启动,systemctl enable supervisord

    3、验证是否为开机启动,systemctl is-enabled supervisord

     常用命令

    supervisor服务端命令
    supervisord –c supervisord.conf 此时默认开启所有服务
    
    supervisor客户端命令
    supervisorctl status 查看进程运行状态
    supervisorctl start 进程名 启动进程
    supervisorctl stop 进程名 关闭进程
    supervisorctl restart 进程名 重启进程
    supervisorctl update重启配置文件修改过的程序,配置没有改动的进程不会收到影响而重启
    supervisorctl reread读取有更新(增加)的配置文件,不会启动新添加的程序,也不会重启任何程序
    supervisorctl reload载入最新的配置文件,停止原有的进程并按照新的配置启动
    supervisorctl shutdown 关闭supervisord
    supervisorctl clear 进程名 清空进程日志
    supervisorctl 进入到交互模式下,使用help查看所有命令
    start stop restart + all 表示启动,关闭,重启所有进程

    注意事项:

    supervisor 默认在以下路径查找配置文件:
    /usr/etc/supervisord.conf, 
    /usr/supervisord.conf, 
    supervisord.conf, 
    etc/supervisord.conf, 
    /etc/supervisord.conf,  
    /etc/supervisor/supervisord.conf
    所以在其他路径使用supervisor命令,需要使用-c指定supervisord.conf的路径

     echo_supervisord_conf   详解:

    mkdir /etc/supervisor
    echo_supervisord_conf > /etc/supervisor/supervisord.conf   根据自己的路径进行配置
    [root@centos-011 ~ 07:50:00]#cat /etc/supervisord.conf.bak
    ; Sample supervisor config file.
     
    [unix_http_server]
    file=/var/run/supervisor/supervisor.sock   ; socket 路径
     
    ;chmod=0700                 ; socket 文件的权限
    ;chown=nobody:nogroup       ; socket 所属用户及组
    ;username=user              ; 用户名
    ;password=123               ; 密码
     
    ;[inet_http_server]         ; 是否启用服务,默认是关闭的(启用的话可以看到supervisor 管理的服务状态)
    ;port=127.0.0.1:9001        ; 监听的IP及端口
    ;username=user              ; 用户名
    ;password=123               ; 密码
     
    [supervisord]               ; supervisord 全局配置
    logfile=/var/log/supervisor/supervisord.log  ; supervisor 日志路径
    logfile_maxbytes=50MB       ; 单个日志文件最大数
    logfile_backups=10          ; 保留多少个日志文件(默认10个)
    loglevel=info               ; (log level;default info; others: debug,warn,trace)
    pidfile=/var/run/supervisord.pid ; pid 文件路径
    nodaemon=false              ; 启动是否丢到前台,设置为false ,表示以daemon 的方式启动
    minfds=1024                 ; 最小文件打开数,对应系统limit.conf 中的nofile ,默认最小为1024,最大为4096
    minprocs=200                ; 最小的进程打开数,对应系统的limit.conf 中的nproc,默认为200
    ;umask=022                  ; (process file creation umask;default 022)
    ;user=chrism                 ; 启动supervisord 服务的用户,默认为root
    ;identifier=supervisor       ; (supervisord identifier, default is 'supervisor')
    ;directory=/tmp              ; 这里的目录指的是服务的工作目录
    ;nocleanup=true              ; (don't clean up tempfiles at start;default false)
    ;childlogdir=/tmp            ; ('AUTO' child log dir, default $TEMP)
    ;environment=KEY=value       ; (key value pairs to add to environment)
    ;strip_ansi=false            ; (strip ansi escape codes in logs; def. false)
     
    ; the below section must remain in the config file for RPC
    ; (supervisorctl/web interface) to work, additional interfaces may be
    ; added by defining them in separate rpcinterface: sections
    [rpcinterface:supervisor]
    supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
     
    [supervisorctl]
    serverurl=unix:///var/run/supervisor/supervisor.sock ; use a unix:// URL  for a unix socket
    ;serverurl=http://127.0.0.1:9001 ; use an http:// url to specify an inet socket
    ;username=chris              ; should be same as http_username if set
    ;password=123                ; should be same as http_password if set
    ;prompt=mysupervisor         ; cmd line prompt (default "supervisor")
    ;history_file=~/.sc_history  ; use readline history if available
     
    ; The below sample program section shows all possible program subsection values,
    ; create one or more 'real' program: sections to be able to control them under
    ; supervisor.
     
    ;[program:theprogramname]      ; 定义一个守护进程 ,比如下面的elasticsearch 
    ;command=/bin/cat              ; 启动程序使用的命令,可以是绝对路径或者相对路径
    ;process_name=%(program_name)s ; 一个python字符串表达式,用来表示supervisor进程启动的这个的名称,默认值是%(program_name)s
    ;numprocs=1                    ; Supervisor启动这个程序的多个实例,如果numprocs>1,则process_name的表达式必须包含%(process_num)s,默认是1
    ;directory=/tmp                ; supervisord在生成子进程的时候会切换到该目录
    ;umask=022                     ; umask for process (default None)
    ;priority=999                  ; 权重,可以控制程序启动和关闭时的顺序,权重越低:越早启动,越晚关闭。默认值是999
    ;autostart=true                ; 如果设置为true,当supervisord启动的时候,进程会自动启动
    ;autorestart=true              ; 设置为随 supervisord 重启而重启,值可以是false、true、unexpected。false:进程不会自动重启
    ;startsecs=10                  ; 程序启动后等待多长时间后才认为程序启动成功,默认是10秒
    ;startretries=3                ; supervisord尝试启动一个程序时尝试的次数。默认是3
    ;exitcodes=0,2                 ; 一个预期的退出返回码,默认是0,2。
    ;stopsignal=QUIT               ; 当收到stop请求的时候,发送信号给程序,默认是TERM信号,也可以是 HUP, INT, QUIT, KILL, USR1, or USR2
    ;stopwaitsecs=10               ; 在操作系统给supervisord发送SIGCHILD信号时等待的时间
    ;user=chrism                   ; 如果supervisord以root运行,则会使用这个设置用户启动子程序
    ;redirect_stderr=true          ; 如果设置为true,进程则会把标准错误输出到supervisord后台的标准输出文件描述符
    ;stdout_logfile=/a/path        ; 把进程的标准输出写入文件中,如果stdout_logfile没有设置或者设置为AUTO,则supervisor会自动选择一个文件位置
    ;stdout_logfile_maxbytes=1MB   ; 标准输出log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小
    ;stdout_logfile_backups=10     ; 标准输出日志轮转备份的数量,默认是10,如果设置为0,则不备份
    ;stdout_capture_maxbytes=1MB   ; 当进程处于stderr capture mode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB
    ;stdout_events_enabled=false   ; 如果设置为true,当进程在写它的stderr
    ;stderr_logfile=/a/path        ; 把进程的错误日志输出一个文件中,除非redirect_stderr参数被设置为true
    ;stderr_logfile_maxbytes=1MB   ; 错误log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小
    ;stderr_logfile_backups=10     ; 错误日志轮转备份的数量,默认是10,如果设置为0,则不备份
    ;stderr_capture_maxbytes=1MB   ; 当进程处于stderr capture mode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB
    ;stderr_events_enabled=false   ; 如果设置为true,当进程在写它的stderr到文件描述符的时候,PROCESS_LOG_STDERR事件会被触发
    ;environment=A=1,B=2           ; 一个k/v对的list列表
    ;serverurl=AUTO                ; 是否允许子进程和内部的HTTP服务通讯,如果设置为AUTO,supervisor会自动的构造一个url
     
    ; The below sample eventlistener section shows all possible
    ; eventlistener subsection values, create one or more 'real'
    ; eventlistener: sections to be able to handle event notifications
    ; sent by supervisor.
     #这个地方是自定义一个守护进程
    [program:elasticsearch]                       ; 定义一个守护进程 elasticsearch
    environment=ES_HOME=/usr/local/elasticsearch  ; 设置ES_HOME 环境变量
    user=elk                                      ; 启动elasticsearch 的用户
    directory=/usr/local/elasticsearch            ; 进入到这个目录中
    command=/usr/local/elasticsearch/bin/elasticsearch ; 执行启动命令
    numprocs=1                                    ; Supervisor启动这个程序的多个实例,如果numprocs>1,则process_name的表达式必须包含%(process_num)s,默认是1
    autostart=true                                ; 设置为随 supervisord 启动而启动
    autorestart=true                              ; 设置为随 supervisord 重启而重启
    startretries=3                                ; 设置elasticsearch 重启的重试次数
    priority=1                                    ; 权重,可以控制程序启动和关闭时的顺序,权重越低:越早启动,越晚关闭。默认值是999  
     
    ;[eventlistener:theeventlistenername]
    ;command=/bin/eventlistener    ; the program (relative uses PATH, can take args)
    ;process_name=%(program_name)s ; process_name expr (default %(program_name)s)
    ;numprocs=1                    ; number of processes copies to start (def 1)
    ;events=EVENT                  ; event notif. types to subscribe to (req'd)
    ;buffer_size=10                ; event buffer queue size (default 10)
    ;directory=/tmp                ; directory to cwd to before exec (def no cwd)
    ;umask=022                     ; umask for process (default None)
    ;priority=-1                   ; the relative start priority (default -1)
    ;autostart=true                ; start at supervisord start (default: true)
    ;autorestart=unexpected        ; restart at unexpected quit (default: unexpected)
    ;startsecs=10                  ; number of secs prog must stay running (def. 1)
    ;startretries=3                ; max # of serial start failures (default 3)
    ;exitcodes=0,2                 ; 'expected' exit codes for process (default 0,2)
    ;stopsignal=QUIT               ; signal used to kill process (default TERM)
    ;stopwaitsecs=10               ; max num secs to wait b4 SIGKILL (default 10)
    ;user=chrism                   ; setuid to this UNIX account to run the program
    ;redirect_stderr=true          ; redirect proc stderr to stdout (default false)
    ;stdout_logfile=/a/path        ; stdout log path, NONE for none; default AUTO
    ;stdout_logfile_maxbytes=1MB   ; max # logfile bytes b4 rotation (default 50MB)
    ;stdout_logfile_backups=10     ; # of stdout logfile backups (default 10)
    ;stdout_events_enabled=false   ; emit events on stdout writes (default false)
    ;stderr_logfile=/a/path        ; stderr log path, NONE for none; default AUTO
    ;stderr_logfile_maxbytes=1MB   ; max # logfile bytes b4 rotation (default 50MB)
    ;stderr_logfile_backups        ; # of stderr logfile backups (default 10)
    ;stderr_events_enabled=false   ; emit events on stderr writes (default false)
    ;environment=A=1,B=2           ; process environment additions
    ;serverurl=AUTO                ; override serverurl computation (childutils)
     
    ; The below sample group section shows all possible group values,
    ; create one or more 'real' group: sections to create "heterogeneous"
    ; process groups.
     
    ;[group:thegroupname]          ; 服务组管理,可以将多个服务名写到这里管理(组名自定义)
    ;programs=progname1,progname2  ; 上面配置好的服务名,比如elasticsearch,kibana,logstash
    ;priority=999                  ; the relative start priority (default 999)
     
    ; The [include] section can just contain the "files" setting.  This
    ; setting can list multiple files (separated by whitespace or
    ; newlines).  It can also contain wildcards.  The filenames are
    ; interpreted as relative to this file.  Included files *cannot*
    ; include files themselves.
     
    [include]
    files = supervisord.d/*.ini
    View Code

    囊括  supervisord.d 文件夹下所有的 conf

    [include]
    files = /usr/supervisor/supervisord.d/*.conf

    若需要web查看进程,则去掉[inet_http_server]的注释

    [inet_http_server]
    port=127.0.0.1:9001   ;IP按需配置     
    username=user              
    password=123

    启动   supervisord

    supervisord -c /usr/supervisor/supervisord.conf

     增加一个配置文件,以便supervisor用来监控程序

    cat > /usr/supervisor/supervisord.d/supervisor_test_one.conf

    在新建的supervisor_test_one.conf文件中添加以下配置

    [program:test_one]
    command=java -jar /data/smallvideo/supervisor/taskApp-exec.jar TaskTestOne  ; 被监控的进程路径
    priority=1                    ; 数字越高,优先级越高
    numprocs=1                    ; 启动几个进程
    autostart=true                ; 随着supervisord的启动而启动
    autorestart=true              ; 自动重启
    startretries=10               ; 启动失败时的最多重试次数
    exitcodes=0                   ; 正常退出代码
    stopsignal=KILL               ; 用来杀死进程的信号
    stopwaitsecs=10               ; 发送SIGKILL前的等待时间
    redirect_stderr=true          ; 重定向stderr到stdout
    
    [program:test_two]
    command=java -jar /data/smallvideo/supervisor/taskApp-exec.jar TaskTestTwo   ; 被监控的进程路径
    priority=1                    ; 数字越高,优先级越高
    numprocs=1                    ; 启动几个进程
    autostart=true                ; 随着supervisord的启动而启动
    autorestart=true              ; 自动重启
    startretries=10               ; 启动失败时的最多重试次数
    exitcodes=0                   ; 正常退出代码
    stopsignal=KILL               ; 用来杀死进程的信号
    stopwaitsecs=10               ; 发送SIGKILL前的等待时间
    redirect_stderr=true          ; 重定向stderr到stdout
    View Code

    supervisor配置文件详解

    - command:启动程序使用的命令,可以是绝对路径或者相对路径
    - process_name:一个python字符串表达式,用来表示supervisor进程启动的这个的名称,默认值是%(program_name)s
    - numprocs:Supervisor启动这个程序的多个实例,如果numprocs>1,则process_name的表达式必须包含%(process_num)s,默认是1
    - numprocs_start:一个int偏移值,当启动实例的时候用来计算numprocs的值
    - priority:权重,可以控制程序启动和关闭时的顺序,权重越低:越早启动,越晚关闭。默认值是999
    - autostart:如果设置为true,当supervisord启动的时候,进程会自动重启。
    - autorestart:值可以是false、true、unexpected。false:进程不会自动重启,unexpected:当程序退出时的退出码不是exitcodes中定义的时,进程会重启,true:进程会无条件重启当退出的时候。
    - startsecs:程序启动后等待多长时间后才认为程序启动成功
    - startretries:supervisord尝试启动一个程序时尝试的次数。默认是3
    - exitcodes:一个预期的退出返回码,默认是0,2- stopsignal:当收到stop请求的时候,发送信号给程序,默认是TERM信号,也可以是 HUP, INT, QUIT, KILL, USR1, or USR2。
    - stopwaitsecs:在操作系统给supervisord发送SIGCHILD信号时等待的时间
    - stopasgroup:如果设置为true,则会使supervisor发送停止信号到整个进程组
    - killasgroup:如果设置为true,则在给程序发送SIGKILL信号的时候,会发送到整个进程组,它的子进程也会受到影响。
    - user:如果supervisord以root运行,则会使用这个设置用户启动子程序
    - redirect_stderr:如果设置为true,进程则会把标准错误输出到supervisord后台的标准输出文件描述符。
    - stdout_logfile:把进程的标准输出写入文件中,如果stdout_logfile没有设置或者设置为AUTO,则supervisor会自动选择一个文件位置。
    - stdout_logfile_maxbytes:标准输出log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小
    - stdout_logfile_backups:标准输出日志轮转备份的数量,默认是10,如果设置为0,则不备份
    - stdout_capture_maxbytes:当进程处于stderr capture mode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB
    - stdout_events_enabled:如果设置为true,当进程在写它的stderr到文件描述符的时候,PROCESS_LOG_STDERR事件会被触发
    - stderr_logfile:把进程的错误日志输出一个文件中,除非redirect_stderr参数被设置为true
    - stderr_logfile_maxbytes:错误log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小
    - stderr_logfile_backups:错误日志轮转备份的数量,默认是10,如果设置为0,则不备份
    - stderr_capture_maxbytes:当进程处于stderr capture mode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB
    - stderr_events_enabled:如果设置为true,当进程在写它的stderr到文件描述符的时候,PROCESS_LOG_STDERR事件会被触发
    - environment:一个k/v对的list列表
    - directory:supervisord在生成子进程的时候会切换到该目录
    - umask:设置进程的umask
    - serverurl:是否允许子进程和内部的HTTP服务通讯,如果设置为AUTO,supervisor会自动的构造一个url
    View Code

    监控demotest程序示例:

    [program:demotest]
    command=python demotest.py 10000  ; 被监控的进程启动命令
    directory=/root/                ; 执行前要不要先cd到目录去,一般不用
    priority=1                    ;数字越高,优先级越高
    numprocs=1                    ; 启动几个进程
    autostart=true                ; 随着supervisord的启动而启动
    autorestart=true              ; 自动重启。。当然要选上了
    startretries=10               ; 启动失败时的最多重试次数
    exitcodes=0                   ; 正常退出代码(是说退出代码是这个时就不再重启了吗?待确定)
    stopsignal=KILL               ; 用来杀死进程的信号
    stopwaitsecs=10               ; 发送SIGKILL前的等待时间
    redirect_stderr=true          ; 重定向stderr到stdout
    View Code

    重启supervisor

    supervisorctl -c /usr/supervisor/supervisord.conf

    supervisor开机自动启动

    在目录/usr/lib/systemd/system/ 新建文件supervisord.service,并添加配置内容

    [Unit]
    Description=Process Monitoring and Control Daemon
    After=rc-local.service nss-user-lookup.target
    
    [Service]
    Type=forking
    ExecStart=/usr/bin/supervisord -c /usr/supervisor/supervisord.conf ;开机启动时执行
    ExecStop=/usr/bin/supervisord shutdown
    ExecReload=/usr/bin/supervisord reload
    killMode=process
    Restart=on-failure
    RestartSec=42s
    
    [Install]
    WantedBy=multi-user.target
    View Code

    启动服务

    systemctl enable supervisord

    验证一下是否为开机启动

    systemctl is-enabled supervisord

     案例配置  supervisord.conf

    [root@hadoop101 supervisor-3.3.5]# cat supervisord.conf 
    
    
    [unix_http_server]
    file=/var/run/supervisor.sock
    
    [inet_http_server]
    port=192.168.1.101:9001
    
    [supervisord]
    logfile=/var/run/supervisord.log;
    logfile_maxbytes=50MB
    logfile_backups=10
    loglevel=info
    pidfile=/var/run/supervisord.pid;
    nodaemon=false
    minfds=1024
    minprocs=200
    
    [rpcinterface:supervisor]
    supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
    
    [supervisorctl]
    serverurl=unix:////var/run/supervisor.sock;
    
    [include]
    files = /opt/module/supervisor-3.3.5/supervisord.d/*.conf
    View Code

    elasticsearch.conf

    [root@hadoop101 supervisord.d]# cat elasticsearch.conf 
    
    [program:elasticsearch]
    command=su -c "/opt/module/elasticsearch-5.6.2/bin/elasticsearch" es
    
    numprocs=1
    
    priority=1
    autostart=true
    autorestart=true
    startretries=10
    exitcodes=0,2
    stopsignal=kill
    stopwaitsecs=10
    
    redirect_stderr=true
    stdout_logfile=/opt/module/elasticsearch-5.6.2/logs/elasticsearch_out.log
    stdout_logfile_maxbytes=20MB
    stdout_logfile_backups=10
    
    stderr_logfile=/opt/module/elasticsearch-5.6.2/logs/elasticsearch_err.log
    stderr_logfile_maxbytes=20MB
    stderr_logfile_backups=10
    View Code

    supervisord 目录

    [root@hadoop101 supervisor-3.3.5]# cat supervisord.conf 
    
    
    [unix_http_server]
    file=/var/run/supervisor.sock
    
    [inet_http_server]
    port=192.168.1.101:9001
    
    [supervisord]
    logfile=/var/run/supervisord.log;
    logfile_maxbytes=50MB
    logfile_backups=10
    loglevel=info
    pidfile=/var/run/supervisord.pid;
    nodaemon=false
    minfds=1024
    minprocs=200
    
    [rpcinterface:supervisor]
    supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
    
    [supervisorctl]
    serverurl=unix:////var/run/supervisor.sock;
    
    [include]
    files = /opt/module/supervisor-3.3.5/supervisord.d/*.
    故乡明
  • 相关阅读:
    请求失败或服务未及时响应。有关详细信息,请参见事件日志或其他适用的错误日志
    12篇学通C#网络编程——第一篇 基础之进程线程(转)
    关于XP和win7前置音频插孔无声音的解决办法
    进程,线程,主线程,异步
    SQL 在什么情况下使用全表扫描
    性能的一些设置
    清除Windows 7通知区域的旧图标
    操作office
    数据库索引
    SCSI
  • 原文地址:https://www.cnblogs.com/luweiweicode/p/14765203.html
Copyright © 2011-2022 走看看