1.安装
宿主机环境:(Centos7)
data:image/s3,"s3://crabby-images/fd039/fd03957155d23a09af9ca2513892e82642d0e57f" alt=""
宿主机环境
#yum install python-setuptools
data:image/s3,"s3://crabby-images/07742/0774249ec13ac424a3f30aa100edfd5cb7aab1d2" alt=""
yum install python-setuptools
#easy_install supervisor
data:image/s3,"s3://crabby-images/e3b6c/e3b6ccaf5327ab441a63db583111d2244a0a248a" alt=""
easy_install supervisor
测试安装是否成功:
#echo_supervisord_conf
data:image/s3,"s3://crabby-images/26bd2/26bd25d6f25c7c5b2a10ea62d24b4e423eddb0a6" alt=""
echo_supervisord_conf
2.创建配置文件
创建supervisor配置文件目录/etc/supervisor/
#mkdir -m 755 -p /etc/supervisor/
data:image/s3,"s3://crabby-images/f8d38/f8d3815fd1364216449ace77c44d353e847e0176" alt=""
mkdir -m 755 -p /etc/supervisor/
创建主配文件supervisord.conf
#echo_supervisord_conf > /etc/supervisor/supervisord.conf
data:image/s3,"s3://crabby-images/cbbe9/cbbe96073d2742a3750767762ee6d00fa91ef5ec" alt=""
echo_supervisord_conf > /etc/supervisor/supervisord.conf
创建项目配置文件目录
# mkdir -m 755 conf.d
data:image/s3,"s3://crabby-images/240b2/240b2c0449b6adbfe4b6cb9574a40de20783c84f" alt=""
# mkdir -m 755 conf.d
3.调试
在/home/k1ic/supervisor_simple 目录下创建test.c
data:image/s3,"s3://crabby-images/e2f1b/e2f1b484e21cbed15aac9e0b69290486db3e53f7" alt=""
test.c
编译为test #gcc -o test test.c
data:image/s3,"s3://crabby-images/8f49a/8f49a902b41c3f2b0ced3f89487dd353a321e0cc" alt=""
gcc -o test test.c
在/etc/supervisor/conf.d 目录下创建 test.ini
data:image/s3,"s3://crabby-images/e4482/e448258c10dd404a193dfae973236c6dfa14238e" alt=""
test.ini
在主配文档中引入test.ini
data:image/s3,"s3://crabby-images/c521d/c521d33aa1203d78ad6d9827163b2be2b18d700d" alt=""
files = ./conf.d/*.ini
启动supervisor
# supervisord -c /etc/supervisor/supervisord.conf
data:image/s3,"s3://crabby-images/bd79a/bd79a38b746e47aa2458a89b383b818ec030c483" alt=""
supervisord -c /etc/supervisor/supervisord.conf
data:image/s3,"s3://crabby-images/4f9cd/4f9cd4115f2acd9f6f7fcd29e7f409b582f012d5" alt=""
pstree -p | grep supervisord
查看supervisord.log发现program test已启动
# cat /tmp/supervisord.log
data:image/s3,"s3://crabby-images/29276/29276341ab3443e92c222db98a5c620b0d8230e5" alt=""
# cat /tmp/supervisord.log
用 supervisorctl 查看已经被监控的program(注:直接用 #supervisorctl 会提示:http://localhost:9001 refused connection)
#supervisorctl -c /etc/supervisor/supervisord.conf
data:image/s3,"s3://crabby-images/60b40/60b40598a8441c3facd5a1a1957d75a735e4d5d5" alt=""
supervisorctl -c /etc/supervisor/supervisord.conf
增加一例监控php脚本
创建skud.ini
data:image/s3,"s3://crabby-images/315c6/315c66cc58bd8f5ae74e6a5a487b1a8c1a49af27" alt=""
skud.ini
data:image/s3,"s3://crabby-images/50b90/50b908d38d0967c4411a6b6c765c89e31ca1b75f" alt=""
[program:skuld]
在/home/k1ic/supervisor_simple目录下创建skuld.php
data:image/s3,"s3://crabby-images/23af2/23af20b9f633b5c6f47c5ed78d6ecff151cd546f" alt=""
skuld.php
重启监控服务
data:image/s3,"s3://crabby-images/e60fe/e60fe0212abe1b6abf5cb979bd7970a72127960f" alt=""
reload
data:image/s3,"s3://crabby-images/68a6f/68a6f9633d45d19136b2c42c7087da3b86581722" alt=""
pstree
================分割线================
这才是重点^^
0. supervisor 比较适合监控业务应用,且只能监控前台程序,php fork方式实现的daemon不能用它监控,否则supervisor> status 会提示:BACKOFF Exited too quickly (process log may have details)
data:image/s3,"s3://crabby-images/61096/610967f7b022bd077b5b71ba6f77371f8ba5698e" alt=""
BACKOFF Exited too quickly (process log may have details)
data:image/s3,"s3://crabby-images/1288c/1288c68887221314fdb310d2b75504dd69e2f3f4" alt=""
cat supervisord.log
1.每次修改配置文件后需进入supervisorctl,执行reload, 改动部分才能生效
data:image/s3,"s3://crabby-images/2cf52/2cf52616df706fc2595c7ce6310bf0629e356bcf" alt=""
reload
2.两个命令
supervisord : supervisor的服务器端部分,用于supervisor启动
supervisorctl:启动supervisor的命令行窗口,在该命令行中可执行start、stop、status、reload等操作。
3.web管理界面
将supervisord.conf中[inet_http_server]部分做相应配置,在supervisorctl中reload即可启动web管理界面
data:image/s3,"s3://crabby-images/9c527/9c52719a39707e80475bf4fbefabb3a63eee70f7" alt=""
[inet_http_server]
data:image/s3,"s3://crabby-images/634e5/634e5e65022c292f399de03a805c1413b86c4af7" alt=""
http://107.170.249.52:9001/?message=Page%20refreshed%20at%20Tue%20Sep%2029%2016%3A20%3A40%202015
参考文献:
Supervisor的安装与使用入门
http://fukun.org/archives/07102224.html
按需讲解之Supervisor
http://www.cnblogs.com/yjf512/archive/2012/03/05/2380496.html
supervisord entered FATAL state, too many start retries too quickly错误处理
http://beginman.cn/linux/2015/09/25/error-about-supervisord/
Supervisor监控PHP进程
http://www.phpddt.com/php/supervisor.html
关于进程监控及自动启动
http://www.vimer.cn/2013/07/%E5%85%B3%E4%BA%8E%E8%BF%9B%E7%A8%8B%E7%9B%91%E6%8E%A7%E5%8F%8A%E8%87%AA%E5%8A%A8%E5%90%AF%E5%8A%A8.html
Supervisor学习
http://beginman.cn/linux/2015/04/06/Supervisor/
通过进程模型进行扩展
http://12factor.net/zh_cn/concurrency
网友评论