博客
关于我
supervisor简洁用例
阅读量:444 次
发布时间:2019-03-06

本文共 2774 字,大约阅读时间需要 9 分钟。

  • supervisor是什么

    superviosr是一个Linux/Unix系统上进程监控和管理的工具,它由python编写,可以用pip安装。supervisor能将一个普通的命令行进程变为后台daemon,并监控进程状态,异常退出时能自动重启

  • 为什么要使用supervisor

    supervisor可以实现单个或成组地控制进程,它可以把web服务的进程组当作自己的子进程,在子进程挂掉时重启。对一组进程进行统一管理是linux没有的功能

  • supervisor组件

    supervisord是管理其他进程的主进程

    supervisorctl是supervisor客户端的命令行工具

  • 主配置文件supervisord.conf

  1. unix_http_server 配置块

    在该配置块的参数项表示的是一个监听在socket上的HTTP server

    [unix_http_server]file=/tmp/supervisor.sock   ; (the path to the socket file)chmod=0766                 ; socket file mode (default 0700)
    • file: unix domain socket的文件路径。supervisorctl通过它与supervisord进行通信

    • chmod: 修改supervisor.sock文件的权限

  2. supervisord 配置块

    该配置块的参数项是关于supervisord进程的全局配置项

    [supervisord]logfile=/tmp/supervisord.log ; (main log file;default $CWD/supervisord.log)logfile_maxbytes=50MB        ; (max main logfile bytes b4 rotation;default 50MB)logfile_backups=10           ; (num of main logfile rotation backups;default 10)loglevel=info                ; (log level;default info; others: debug,warn,trace)pidfile=/tmp/supervisord.pid ; (supervisord pidfile;default supervisord.pid)nodaemon=false               ; (start in foreground if true;default false)minfds=1024                  ; (min. avail startup file descriptors;default 1024)minprocs=200                 ; (min. avail process descriptors;default 200)
    • logfile: log文件路径。与子进程的日志不同

    • logfile_maxbytes: log文件达到多少自动进行轮转,单位是kb、单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小。当日志大小超过50MB时,生成一个新的日志文件

    • logfile_backups:轮转日志备份的数量,默认是10,如果设置为0,则不备份

    • loglevel:error、warn、info、debug、trace、blather、critical

    • pidfile:pid文件路径

    • nodaemon:如果设置为true,则supervisord在前台启动,而不是以守护进程启动

    • minfds:supervisord在成功启动前最少系统空闲的文件描述符,默认1024

    • minprocs:supervisord在成功启动前最小可用的进程描述符,默认200

  3. supervisorctl配置块

    [supervisorctl]serverurl=unix:///tmp/supervisor.sock ; use a unix:// URL  for a unix socket
    • serverurl: 这个是supervisorctl本地连接supervisord的时候,本地UNIX socket路径,注意这个是和前面的[unix_http_server]对应的
      默认值就是unix:///tmp/supervisor.sock
  4. rpcinterface配置块

    这个选项是给XML_RPC用的,如果想使用supervisord或者web server这个选项必须要开启

    [rpcinterface:supervisor]supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
  5. include配置块

    用于将写在cong.d中的*.ini文件内容读入主配置文件

    一般一个ini文件包含一个program配置块。用于配置web服务进程的启动命令、目录、日志位置等

    [include]files = /etc/supervisor/conf.d/*.ini
  • program配置块

    [program:myserver]command=/home/my_web_server/venv/bin/gunicorn -w4 -b0.0.0.0:8105 app.wsgi:applicationdirectory=/home/my_web_server/user=deploystdout_logfile=/home/logs/server.logstderr_logfile=/home/logs/server.err.log
    • command:启动程序使用的命令,可以是绝对路径也可以是相对路径

    • directory:supervisord在生成子进程的时候会切换到该目录

    • user: 如果supervisord以root运行,则会使用这个设置用户启动子程序

    • stdout_logfile:进程标准输出的文件位置

    • stderr_logfile:进程错误日志输出的文件位置

    还有一些可选配置:

    • autorestart = true 在子进程挂掉后重启

    • priority=1子进程启动关闭优先级,优先级低的,最先启动,关闭的时候最后关闭。数字越高,优先级越高

    • numprocs=1启动进程的数目

  • 在新建了ini配置文件后,要用supervisorctl重新加载配置文件

    supervisorctl reload

转载地址:http://zulyz.baihongyu.com/

你可能感兴趣的文章
Nginx面试三连问:Nginx如何工作?负载均衡策略有哪些?如何限流?
查看>>
nginx:/usr/src/fastdfs-nginx-module/src/common.c:21:25:致命错误:fdfs_define.h:没有那个文件或目录 #include
查看>>
Nginx:NginxConfig可视化配置工具安装
查看>>
ngModelController
查看>>
ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
查看>>
ngrok内网穿透可以实现资源共享吗?快解析更加简洁
查看>>
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
nid修改oracle11gR2数据库名
查看>>
NIFI1.21.0/NIFI1.22.0/NIFI1.24.0/NIFI1.26.0_2024-06-11最新版本安装_采用HTTP方式_搭建集群_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
查看>>
NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>