Python Supervisord 进程管理工具

Posted siwnckhhw

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python Supervisord 进程管理工具相关的知识,希望对你有一定的参考价值。

分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!http://www.captainbed.net

Supervisord,用Python实现的一款非常实用的进程管理工具,在批量服务化管理时特别有效。


环境
centos
python2.6.6


安装 
wget http://pypi.python.org/packages/source/s/supervisor/supervisor-3.0a10.tar.gz
tar zxvf supervisor-3.0a10.tar.gz
cd supervisor-3.0a10
python setup.py install
如果上述遇到问题,请按如下操作。


依赖setuptools安装
wget https://pypi.python.org/packages/2.6/s/setuptools/setuptools-0.6c11-py2.6.egg
sh setuptools-0.6c11-py2.6.egg

更多 setuptools


产生基础配置文件
echo_supervisord_conf > /etc/supervisord.conf


配置
[inet_http_server]前面的分号去掉; 如下:

技术图片


启动
/usr/local/bin/supervisord -c /etc/supervisord.conf

 

关闭

username=user
passwd=123
/usr/local/bin/supervisorctl -u{$username} -p{$passwd} stop all
/usr/local/bin/supervisorctl -u{$username} -p{$passwd} shutdown


查看
浏览器打开 http://127.0.0.1:9001

如下图:

技术图片



深入配置

[program:service]
command=sh /opt/soft/service/run.sh  ; 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)
directory=/opt/soft/service/                ; directory to cwd to before exec (def no cwd)
autostart=true                ; start at supervisord start (default: true)
autorestart=true              ; retstart at unexpected quit (default: true)
stopsignal=QUIT               ; signal used to kill process (default TERM)
stopwaitsecs=10               ; max num secs to wait b4 SIGKILL (default 10)
以上配置了一个shell脚本的启动和stop过程。
一般java程序都喜欢在一个shell脚本内初始化classpath,再执行java main。
直接在shell中run java会出现stop失败的情况,在启动前添加 exec即可。

#!/bin/sh
export CLASSPATH=.
for jarpath in `ls library/*.jar`
do
    CLASSPATH=$CLASSPATH:$jarpath
done
export CLASSPATH=$CLASSPATH
exec java com.chen.main;


帮助

supervisord,初始启动Supervisord,启动、管理配置中设置的进程。
supervisorctl stop programxxx,停止某一个进程(programxxx),programxxx为[program:chatdemon]里配置的值,这个示例就是chatdemon。
supervisorctl start programxxx,启动某个进程
supervisorctl restart programxxx,重启某个进程
supervisorctl stop all,停止全部进程,注:start、restart、stop都不会载入最新的配置文件。
supervisorctl reload,载入最新的配置文件,并按新的配置启动、管理所有进程。

http://smarden.org/runit/runscripts.html 一些可参考的启动配置

 

注意 
不带参数运行supervisord是以daemon方式运行。
把supervisord加入到开机启动项里就可以完成监控进程的功能了。
当supervisord以非daemon方式运行时,杀掉supervisord后,被监控的进程也退出了。
而以daemon方式运行,杀掉supervisord对被监控进程无影响。

 

 

 

参考推荐:

Supervisord管理Python进程

Supervisord管理杂乱的服务

Linux /proc/pid记录了什么

 

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!http://www.captainbed.net

以上是关于Python Supervisord 进程管理工具的主要内容,如果未能解决你的问题,请参考以下文章

进程管理工具-Supervisord 使用

supervisord使用

supervisord

使用supervisord 管理ELK进程

logstash使用supervisord

管理 AirFlow 方法