Supervisor(http://supervisord.org/)是用Python开发的一个client/server服务,是Linux/Unix系统下的一个进程管理工具,不支持Windows系统。它可以很方便的监听、启动、停止、重启一个或多个进程。用Supervisor管理的进程,当一个进程意外被杀死,supervisort监听到进程死后,会自动将它重新拉起,很方便的做到进程自动恢复的功能,不再需要自己写shell脚本来控制。

  因为Supervisor是Python开发的,安装前先检查一下系统否安装了Python2.4以上版本。

1.安装

  1. .mac下,可以先安装brew,然后通过brew来安装各种工具
  2. brew install supervisor
  3. .Ubuntu系统下:apt-get install supervisor,通过这种方式安装后,自动设置为开机启动
  4. .也可以通过 pip install supervisor 进行安装,但是需要手动启动,然后设置为开机启动(不推荐这种安装方式)

2.配置

2.1supervisor配置

Supervisor 是一个 C/S 模型的程序,supervisord 是 server 端,supervisorctl 是 client 端。

下面介绍 supervisord 配置方法。supervisord 的配置文件默认位于 /etc/supervisor/supervisord.conf,内容如下(;后面为注释):

  1. ; supervisor config file
  2.  
  3. [unix_http_server]
  4. file=/var/run/supervisor.sock ; (the path to the socket file) UNIX socket 文件,supervisorctl 会使用
  5. chmod= ; sockef file mode (default ) socket 文件的 mode,默认是
  6.  
  7. [supervisord]
  8. logfile=/var/log/supervisor/supervisord.log ; (main log file;default $CWD/supervisord.log) 日志文件,默认是 $CWD/supervisord.log
  9. pidfile=/var/run/supervisord.pid ; (supervisord pidfile;default supervisord.pid) pid 文件
  10. childlogdir=/var/log/supervisor ; ('AUTO' child log dir, default $TEMP)
  11.  
  12. ; the below section must remain in the config file for RPC
  13. ; (supervisorctl/web interface) to work, additional interfaces may be
  14. ; added by defining them in separate rpcinterface: sections
  15. [rpcinterface:supervisor]
  16. supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
  17.  
  18. [supervisorctl]
  19. serverurl=unix:///var/run/supervisor.sock ; use a unix:// URL for a unix socket 通过 UNIX socket 连接 supervisord,路径与 unix_http_server 部分的 file 一致
  20.  
  21. ; 在增添需要管理的进程的配置文件时,推荐写到 `/etc/supervisor/conf.d/` 目录下,所以 `include` 项,就需要像如下配置。
  22. ; 包含其他的配置文件
  23. [include]
  24. files = /etc/supervisor/conf.d/*.conf ; 引入 `/etc/supervisor/conf.d/` 下的 `.conf` 文件

2.2管理进程配置

program 的配置文件就写在,supervisord 配置中 include 项的路径下:/etc/supervisor/conf.d/,然后 program 的配置文件命名规则推荐:app_name.conf

  1. [program:app] ; 程序名称,在 supervisorctl 中通过这个值来对程序进行一系列的操作
  2. autorestart=True ; 程序异常退出后自动重启
  3. autostart=True ; supervisord 启动的时候也自动启动
  4. redirect_stderr=True ; stderr 重定向到 stdout,默认 false
  5. environment=PATH="/home/app_env/bin" ; 可以通过 environment 来添加需要的环境变量,一种常见的用法是使用指定的 virtualenv 环境
  6. command=python server.py ; 启动命令,与手动在命令行启动的命令是一样的
  7. user=ubuntu ; 用哪个用户启动
  8. directory=/home/app/ ; 程序的启动目录
  9. stdout_logfile_maxbytes = 20MB ; stdout 日志文件大小,默认 50MB
  10. stdout_logfile_backups = ; stdout 日志文件备份数
  11. ; stdout 日志文件,需要注意当指定目录不存在时无法正常启动,所以需要手动创建目录(supervisord 会自动创建日志文件)
  12. stdout_logfile = /data/logs/usercenter_stdout.log

需要注意:

  • 用 supervisord 管理时,gunicorn 的 daemon 选项需要设置为 False
  • 如果启动命令需要包含workon,修改environment参数:environment=PATH="/home/username/.virtualenvs/myproject/bin"

案例:

配置Django项目,启动方式:supervisorctl start test

  1. [program:test]
  2. command=/srv/envs/mimas/bin/gunicorn gm_rpcd.wsgi:application --workers= -k gevent --bind=0.0.0.0: --user=test --chdir /srv/apps/test/
  3. environment="指定项目的虚拟环境路径"
  4. user=test
  5. stdout_logfile=/data/log/test/supervisor/supervisor.stdout.log
  6. stdout_logfile_maxbytes=1MB
  7. stdout_logfile_backups=
  8. stderr_logfile=/data/log/test/supervisor/supervisor.stderr.log
  9. stderr_logfile_maxbytes=1MB
  10. stderr_logfile_backups=

配置celery,启动方式:supervisorctl start test-celery

  1. [program:test-celery]
  2. command=/srv/envs/test/bin/celery worker -A user_hierarchy --loglevel=DEBUG -c
  3. directory=/srv/apps/test
  4. user=test
  5. stdout_logfile=/data/log/test/supervisor/celery.log
  6. stderr_logfile=/data/log/test/supervisor/celery_error.log
  7. startsecs=
  8. stopwaitsecs =
  9. stopasgroup=true
  10. killasgroup=true

配置celery-beat,启动方式:supervisorctl start test-beat

  1. [program:test-celerybeat]
  2. command=/srv/envs/test/bin/celery beat -A user_hierarchy --loglevel=DEBUG # 启动这个任务的命令
  3. directory=/srv/apps/test
  4. user=test
  5. stdout_logfile=/data/log/test/supervisor/celerybeat.log
  6. stderr_logfile=/data/log/test/supervisor/celerybeat_error.log
  7. startsecs=
  8. stopwaitsecs =
  9. stopasgroup=true
  10. killasgroup=true

3.supervisorctl

supervisorctl 是 supervisord 的命令行客户端工具,使用的配置和 supervisord 一样

  1. supervisorctl status 查看所有进程状态
  2. supervisorctl stop tomcat 停止某个进程
  3. supervisorctl start tomcat 启动某个进程
  4. supervisorctl restart tomcat 重启某个进程

4.web管理界面配置

  1. [unix_http_server]
  2. file=/tmp/supervisor.sock ;UNIX socket 文件,supervisorctl 会使用
  3. ;chmod= ;socket文件的mode,默认是0700
  4. ;chown=nobody:nogroup ;socket文件的owner,格式:uid:gid
  5.  
  6. ;[inet_http_server] ;HTTP服务器,提供web管理界面
  7. ;port=127.0.0.1: ;Web管理后台运行的IP和端口,如果开放到公网,需要注意安全性
  8. ;username=user ;登录管理后台的用户名
  9. ;password= ;登录管理后台的密码

出于安全考虑,默认配置是没有开启web管理界面,需要修改supervisord.conf配置文件打开http访权限。

需要访问,则去掉前面的分号,配置端口即可。

5.启动supervisor服务

  1. supervisord -c /etc/supervisor/supervisord.conf

6.配置开机启动supervisor服务

6.1配置systemctl服务

1> 进入/lib/systemd/system目录,并创建supervisor.service文件

  1. [Unit]
  2. Description=supervisor
  3. After=network.target
  4.  
  5. [Service]
  6. Type=forking
  7. ExecStart=/usr/bin/supervisord -c /etc/supervisor/supervisord.conf
  8. ExecStop=/usr/bin/supervisorctl $OPTIONS shutdown
  9. ExecReload=/usr/bin/supervisorctl $OPTIONS reload
  10. KillMode=process
  11. Restart=on-failure
  12. RestartSec=42s
  13.  
  14. [Install]
  15. WantedBy=multi-user.target

2> 设置开机启动

  1. systemctl enable supervisor.service
  2. systemctl daemon-reload

  3>修改文件权限为766

  1. chmod supervisor.service

6.2配置service类型服务

参考:https://blog.csdn.net/xyang81/article/details/51555473

supervisor管理进程工具配置的更多相关文章

  1. Supervisor 管理进程,Cloud Insight 监控进程,完美!

    Supervisor 是由 Python 语言编写.基于 linux 操作系统的一款服务器管理工具,用于监控服务器的运行,发现问题能立即自动预警及自动重启等. Cloud Insight 是一款次世代 ...

  2. supervisor管理进程 superlance对进程状态报警

    supervisor介绍 首先,介绍一下supervisor.Supervisor(http://supervisord.org/)是用Python开发的一个client/server服务,是Linu ...

  3. Linux服务:使用Supervisor管理进程

    一.简介 由于基本每个公司都会用到supervisor这个进程管理工具,这里简单阐述一下. Supervisor (http://supervisord.org) 是一个用Python写Linux下的 ...

  4. Supervisor管理进程

    Supervisor管理进程 转载 2016年04月14日 18:26:45 标签: supervisord 28344 Supervisor重新加载配置启动新的进程 liaojie 发布于 1年前, ...

  5. Django与supervisor 管理进程

    1.前言 在Django项目中,我们需要用到一些独立于Django框架外的脚本.这样一些脚本可能需要独立的持续运行,且具有很强的可维护性,这个时候supervisor就可以排上用场了. 基于pytho ...

  6. Mac Supervisor 管理进程

    无论是在日常工作中还是平时玩代码中,我总是离不开 Supervisor,其实很久之前我就写过一篇文章:supervisord 部署 Flask,在里面,我仔细讲解了如何在 Linux 环境下安装并且配 ...

  7. 在Docker里使用(支持镜像继承的)supervisor管理进程(转)

    这篇文章是受 dockboard 之托帮忙翻译的与 docker 有关的技术文章.译自 Using Supervisor with Docker to manage processes (suppor ...

  8. php使用supervisor管理进程脚本

    supervisor是用python开发的一个在linux系统下的进程管理工具,可以方便的监听,启动,停止一个或多个进程.当一个进程被意外杀死后,supervisor监听到后,会自动重新拉起进程. 一 ...

  9. pm2 代替 Supervisor 管理进程

    前提 我们在使用 Laravel 的时候不免用到列队来处理任务,而 Laravel 官方文档给出的是 Supervisor 来管理进程和监控.但是我们在使用中有下面几个缺点: Supervisor 单 ...

随机推荐

  1. C++学习3--编程基础(vector、string、三种传参)

    知识点学习 Vector容器 vector是C++标准程序库中的一个类,其定义于头文件中,与其他STL组件一样,ventor属于STD名称空间: ventor是C++标准程序库里最基本的容器,设计之初 ...

  2. Linux内存管理--基本概念【转】

    转自:http://blog.csdn.net/myarrow/article/details/8624687 1. Linux物理内存三级架构 对于内存管理,Linux采用了与具体体系架构不相关的设 ...

  3. API 开发平台 dreamfactory,参考SAWAGGER,国外厂家,开源,本地与云部署

    API 开发平台,参考SAWAGGER,国外厂家,本地与云部署:参考  http://swagger.io/commercial-tools/ 1.dreamfactory 梦工厂公司  https: ...

  4. jvm系列三、java GC算法 垃圾收集器

    原文链接:http://www.cnblogs.com/ityouknow/p/5614961.html 概述 垃圾收集 Garbage Collection 通常被称为“GC”,它诞生于1960年 ...

  5. oracle查询重复数据方法

    SQL重复记录查询方法 2008年08月14日 星期四 21:01 SQL重复记录查询 1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断select * from peop ...

  6. mysql的日志及利用mysqldump备份及还原

    日志文件:6类       一般查询日志:log,general_log,log_output       慢查询日志:       错误日志       二进制日志       中继日志       ...

  7. discuz3.4:在Centos6.5中安装过程

    参考文章:https://www.cnblogs.com/hehongbin/articles/5741270.html https://www.cnblogs.com/mitang/p/552454 ...

  8. S5PV210串口

    串口设置之输入输出字符 S5PV210 UART相关说明        通用异步收发器简称UART,即UNIVERSAL ASYNCHRONOUS RECEIVER AND TRANSMITTER,它 ...

  9. OCM_第十五天课程:Section6 —》数据库性能调优 _SQL 访问建议 /SQL 性能分析器/配置基线模板/SQL 执行计划管理/实例限制

    注:本文为原著(其内容来自 腾科教育培训课堂).阅读本文注意事项如下: 1:所有文章的转载请标注本文出处. 2:本文非本人不得用于商业用途.违者将承当相应法律责任. 3:该系列文章目录列表: 一:&l ...

  10. laravel 接口跨域

    最方便的方法,新建一个middleWare,把这个middleware加入到全局中间件,所有的请求,都会经过这个中间件的过滤. php artisan make:middleware CrossHtt ...