supervisor 进程管理

主要包含后台进程 supervisord 和控制台 supervisorctl 两个程序

supervisor
# 官方文档 http://www.supervisord.org/installing.html

# 此程序是用python开发,python2.7.x 运行中没有发现问题.
# 目标机器没有pip, 所以使用离线安装. 下载以下三个压缩包最新版:
# https://pypi.org/pypi/supervisor/
# https://pypi.org/pypi/setuptools/
# https://pypi.org/pypi/meld3/ # 复制到目标机器, 解压,安装.
sudo tar zxf meld3-2.0..tar.gz
sudo tar zxf supervisor-4.0..tar.gz
sudo unzip setuptools-41.2..zip cd setuptools-41.2.
sudo python setup.py install cd ../meld3-2.0.
sudo python setup.py install cd ../supervisor-4.0.
sudo python setup.py install # 留意安装信息显示的安装位置
...
Installing echo_supervisord_conf script to /usr/bin
Installing supervisorctl script to /usr/bin
Installing supervisord script to /usr/bin # 生成配置文件示例格式,可在此基础修改
echo_supervisord_conf > /etc/supervisor/supervisord.conf # ------------------------- supervisord.conf ---------------------------
[unix_http_server]
file=/tmp/supervisor.sock ; (the path to the socket file) [inet_http_server]
port=0.0.0.0:
username=admin
password= [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= ; (num of main logfile rotation backups;default )
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= ; (min. avail startup file descriptors;default )
minprocs= ; (min. avail process descriptors;default ) [rpcinterface:supervisor]
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface [supervisorctl]
serverurl=unix:///tmp/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=admin ; should be same as http_username if set
password= ; should be same as http_password if set [include]
files = conf.d/*.conf # 使用包含子目录的方式,指定单个接管的程序
# ------------------------- /etc/supervisor/conf.d/test.demo.conf ---------------
[program:test.demo]
command=dotnet Csharp_class.dll
directory=/webapp/test.demo/
process_name=%(program_name)s
stderr_logfile=/var/log/test.demo.log
stdout_logfile=/var/log/test.demo.log
environment=ASPNETCORE_ENVIRONMENT=Production
user=root
stopsignal=INT
autostart=true
autorestart=true
startsecs=3 # 启动服务
# 可以 -c 指定配置文件,也可不指定,程序将自动寻找 supervisor.conf
sudo supervisord -c /etc/supervisor/supervisord.conf # 注意:一台机器不能有多个同名配置文件.
# 某服务器就因为有 /etc/supervisord.conf 但是启动服务用的 -c /etc/supervisor/supervisord.conf
# 两处配置文件内容不同导致进入 supervisorctl 始终出现错误: unix ///var/run/supervisor.sock refused connection # ----------------------------- shell ----------------------------------
supervisorctl # 进入shell 如果配置正确,登录后将直接列出管理的程序 status # 列出状态
version # 版本
help
shutdown # 结束 supervisord 服务
reread # 重读配置文件,列出变化
update # 重读配置文件并生效(默认更新全部),指定名称则更新单个

start test # 启动单个
start all # 启动全部
stop test # 停止单个
stop all # 停止全部
restart test # 重启单个
restart all # 重启全部
remove test.demo # 移除 test.demo
## 如果更改了配置文件,一定要先reread, 然后 update ,
# 直接 restart 只会重新载入程序代码,不会重载配置文件。
# 例如我改了/etc/supervisor/conf.d/demo.conf
# 必须先reread, 提示发现变化后,再执行 update demo 才能让配置生效。

如果需要开机自动启动,可将其安装为系统服务:

# --------------- 安装为系统服务 ---------------------------------------
# 安装时会产生服务文件: cat /usr/lib/systemd/system/supervisord.service
# ll /etc/systemd/system/multi-user.target.wants 时可以
# 看到supervisord.service文件的真实链接
# 当 systemctl enable supervisord 时,则将此链接作为服务配置文件 [Unit]
Description=Process Monitoring and Control Daemon
After=rc-local.service nss-user-lookup.target [Service]
Type=forking
ExecStart=/usr/bin/supervisord -c /etc/supervisor/supervisord.conf
ExecStop=/usr/bin/supervisorctl shutdown
ExecReload=/usr/bin/supervisorctl reload
KillMode=process
Restart=on-failure
RestartSec=42s [Install]
WantedBy=multi-user.target # 如果已经有运行的 supervisor及程序,需要先进入shell, stop all
# 然后再 kill -9 对应的supervisor主程序,使用服务管理的方式启动。
sudo systemctl enable supervisord
sudo systemctl start supervisord
sudo systemctl status supervisord
sudo systemctl list-unit-files   # 检查列表中是否存在并且 enabled

systemd 参考: http://www.ruanyifeng.com/blog/2016/03/systemd-tutorial-commands.html

今天加入了一个nodejs程序, 添加配置文件到 /etc/supervisor/conf.d

[program:parsoid]
command=node bin/server.js
directory=/opt/parsoid
process_name=%(program_name)s
stderr_logfile=/opt/parsoid/logs/err.log
stdout_logfile=/opt/parsoid/logs/parsoid.log user=root
stopsignal=INT
autostart=true
autorestart=true
startsecs=3

依次执行下方测试:

supervisorctl

>reread  # 发现
>update >status
>stop parsoid # 测试停止
>start parsoid # 测试启动
>status

我现在的公司,主要用它来管理 dotnet 程序

centos7 安装 dotnet-sdk

rpm -Uvh https://packages.microsoft.com/config/rhel/7/packages-microsoft-prod.rpm

yum install dotnet-sdk-3.1

supervisor 管理应用程序的更多相关文章

  1. 配置supervisor管理beego应用

    一.golang.beego等环境安装与配置 二.supervisor安装 github项目地址:https://github.com/Supervisor/supervisor 克隆项目:git c ...

  2. 使用Supervisor管理Celery进程。

    讲过一篇celery的,但是celery启动后并不是daemon的,在生产环境中这肯定是不可以的,那怎么办呢? 这就需要使用supervisor进行进程管理了,下面详细介绍. 一. superviso ...

  3. 如何使用supervisor管理你的应用

    1.前言 Supervisor(http://supervisord.org/)是用Python开发的一个client/server服务,是UNIX-like系统下的一个进程管理工具,不支持Windo ...

  4. 使用supervisor管理进程

    Supervisor (http://supervisord.org) 是一个用 Python 写的进程管理工具,可以很方便的用来启动.重启.关闭进程(不仅仅是 Python 进程).除了对单个进程的 ...

  5. Supervisor管理进程

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

  6. supervisor管理进程工具配置

    Supervisor(http://supervisord.org/)是用Python开发的一个client/server服务,是Linux/Unix系统下的一个进程管理工具,不支持Windows系统 ...

  7. supervisor 管理uwsgi 进程

    Supervisor是用Python开发的一套通用的进程管理程序,能将一个普通的命令行进程变为后台daemon,并监控进程状态,异常退出时能自动 重启.它是通过fork/exec的方式把这些被管理的进 ...

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

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

  9. 使用Supervisor管理Linux进程

    使用Supervisor管理Linux进程 简介 Supervisor是一个C/S系统,它可以在类UNIX系统上控制系统进程,由python编写,提供了大量的功能来实现对进程的管理. 安装 sudo ...

随机推荐

  1. Python类定义、属性、初始化和析构

    类的定义,属性和方法概念 方法中self的作用和意义 初始化( __init__ ) 和 析构方法( __del__ ) 类的定义 class 类名 实例 实例名 = 类名() 一个“实例”的“特征” ...

  2. C++ 基础语法 快速复习笔记(3)---重载函数,多态,虚函数

    1.重载运算符和重载函数: C++ 允许在同一作用域中的某个函数和运算符指定多个定义,分别称为函数重载和运算符重载. 重载声明是指一个与之前已经在该作用域内声明过的函数或方法具有相同名称的声明,但是它 ...

  3. Windows | Ubuntu18.04分别安装Matlab 2017b破解版

    首先下载好Windows和Ubuntu 版本的MATLAB 2017b 安装包, 1.Windows上安装,解压文件R2017b_win64_dvd1.iso和R2017b_win64_dvd2.is ...

  4. PHP 循环引用的问题

    问题 为了引出问题, 先来看下面一段代码: <?php $arr = [ 'a', 'b', 'c', 'd', ]; foreach ($arr as &$each){ echo $e ...

  5. 鲜贝7.3--mysql安装

    1.安装包下载 首先是下载 mysql-installer-community-5.6.14.0.msi ,大家可以到 mysql 官方网去下载. win10的安全机制比较严格,安装前最好到<设 ...

  6. Django views 中的装饰器

    关于装饰器 示例: 有返回值的装饰器:判断用户是否登录,如果登录继续执行函数,否则跳回登录界面 def auth(func): def inner(request, *args, **kwargs): ...

  7. 弄明白kubernetes中的“三种IP”

    Node IP : Node节点的IP地址 Pod IP:Pod的IP地址 Cluster IP : Service 的IP地址 首先,Node IP是Kubernetes集群中每个节点(服务器)物理 ...

  8. Qt所有滚动条的样式

    const QString QSS_VerticalScrollBar = "" "QScrollBar:vertical{" //垂直滑块整体 "m ...

  9. 谈谈vue.js中methods watch和compute的区别和联系

    methods,watch和computed都是以函数为基础的,但各自却都不同: 1.watch和computed都是以Vue的依赖追踪机制为基础的,它们都试图处理这样一件事情:当某一个数据(称它为依 ...

  10. 可能会搞砸你的面试:你知道一个TCP连接上能发起多少个HTTP请求吗?

    本文由原作者松若章原创发布,作者主页:zhihu.com/people/hrsonion/posts,感谢原作者的无私分享. 1.引言 一道经典的面试题是:从 URL 在浏览器被被输入到页面展现的过程 ...