supervisor学习笔记

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介:

官方手册:http://www.supervisord.org/

 

安装 supervisor可以采用快捷的安装方式如下:

yum install python-setuptools -y

easy-install supervisor 或者pip install supervisor

 

 

下面是编译安装的步骤:

CentOS6.7为例,原始安装包存放在/home/tools/supervisor/src下。

 

下面是一个自动安装的脚本:

文件目录结构如下:

├── install.sh

└── src

    └── supervisor-3.3.1.tar.gz

install.sh内容如下:

#!/bin/bash

#auto install supervisor-3.3.1

 

yum install python-setuptools -y

tar xf src/supervisor-3.3.1.tar.gz  -C src/

cd src/supervisor-3.3.1

python setup.py install

echo_supervisord_conf > /etc/supervisord.conf

if[ $? = 0 ];then

    echo -e "---------- $(date +"%F%T") installed supervisor Success. --------------\n" | tee -a../../install.log

else

    echo -e "---------- $(date +"%F%T") installed supervisor Failed. --------------\n" | tee -a ../../install.log

fi

 

简单的配置supervisor

vim  /etc/supervisord.conf 在最后添加上如下的内容:

[program:redis]

;注意:使用supervisor 来监控redis自启动的话,必须设置为前台redis运行,不然会报错。

command=/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf

autorstart=true

autorestart=true

stdout_logfile=/tmp/supervisor.log

 

[inet_http_server]                                                                                                           

;warning:itis better add one iptables rule to deny others access 9001 port

port=*:9001

username=root

password=123456

 

 

执行 supervisord -c /etc/supervisord.conf 即可启动守护进程

 

执行:supervisorctl status 即可列出服务的状态。

redis             RUNNING   pid 19135, uptime 0:03:42

 

注意:

    supervisor 比较适合监控业务应用,且只能监控前台程序(进程必须以非daemon方式运行)php fork方式实现的daemon不能用它监控,

    否则supervisor> status 会提示:BACKOFF  Exited too quickly(process log may have details)

    经过适当的修改后,redisnginxmysqltomcat都可以使用supervisor来监控。

 

注意:

    每次修改完/etc/supervisord.conf ,需要执行supervisorctl reload来重启supervisord进程,不然修改的配置无法生效。

 

 

    启动supervisord

       supervisord -c /etc/supervisord.conf

   

    关闭supervisord

       supervisorctl shutdown

   

    重新载入配置

       supervisorctl reload

 

supervisor组件说明:

    supervisord

       supervisordsupervisor的服务端程序。

       干的活:启动supervisor程序自身,启动supervisor管理的子进程,响应来自clients的请求,重启闪退或异常退出的子进程,把子进程的stderrstdout记录到日志文件中,生成和处理Event

   

    supervisorctl

       这东西还是有点用的,如果说supervisordsupervisor的服务端程序,那么supervisorctl就是client端程序了。

       supervisorctl有一个类型shell的命令行界面,我们可以利用它来查看子进程状态,启动/停止/重启子进程,获取running子进程的列表等等。。。

       最牛逼的一点是,supervisorctl不仅可以连接到本机上的supervisord,还可以连接到远程的supervisord,当然在本机上面是通过UNIX socket连接的。

       supervisorctlsupervisord之间的通信,是通过xml_rpc完成的,远程是通过TCP socket连接的。

       supervisorctlsupervisord之间的通信,是通过xml_rpc完成的。相应的配置在[supervisorctl]块里面

   

    Web Server

       Web Server主要可以在界面上管理进程,Web Server其实是通过XML_RPC来实现的,可以向supervisor请求数据,也可以控制supervisor及子进程。配置在[inet_http_server]块里面

   

    XML_RPC接口

       这个就是远程调用的,上面的supervisorctlWeb Server就是它弄的



#####下面是几个测试没问题的样例,自己测试supervisor启动 redis mysqld nginx tomcat都没问题。

[inet_http_server]

;注意:需要配置防火墙只允许公司的IP访问9001端口

port=*:9001

username=sup_admin

password=flzxsqc@!@#$

 

[program:redis]

;注意:使用 supervisor 来监控redis自启动的话,必须设置daemonize no,不然会报错。

command=/usr/local/redis/bin/redis-server/usr/local/redis/etc/redis.conf

autorstart=true

autorestart=true

stdout_logfile=/tmp/supervisor_redis.log

 

[program:mariadb]

command=/usr/local/mariadb/bin/mysqld --basedir=/usr/local/mariadb --datadir=/data/ mysql--plugin-dir=/usr/local/mariadb/lib/plugin --user=mariadb --log-error=/data/mysql/mariadb.err --pid-file=/data/mysql/mariadb.pid --socket=/tmp/mysql.sock --port=3306

autostart=true

autorestart=true

stdout_logfile=/tmp/supervisor_mariadb.log

 

[program:nginx]

;注意:使用 supervisor 来监控nginx自启动的话,必须修改nginx.conf 在前几行添加上daemon off;

command=/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

autostart=true

autorestart=true

sutdout_logfile=/tmp/supervisor_nginx.log

 

[program:tomcat7]

command=/usr/local/tomcat/bin/catalina.sh run

autorstart=true

user=webserver

autorestart=true

stdout_logfile=/tmp/supervisor_tomcat7.log



做到这里,还要给supervisor添加个开机自启动啊。

各种自启动脚本的地址:https://github.com/Supervisor/initscripts


下面是一个自己写的功能简陋的脚本:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#!/bin/bash
# chkconfig: 345 83 04
# description: Supervisor start stop script
start() {
/usr/bin/supervisord  -c  /etc/supervisord .conf
}
stop() {
/usr/bin/supervisorctl  shutdown
}
restart() {
stop
start
}
reload() {
/usr/bin/supervisorctl  reload
}
case  "$1"  in
     start)
         start
         ;;
     stop)
         stop
         ;;
     restart)
         restart
         ;;
     reload)
             reload
             ;;
     *)
         echo  $ "Usage: $0 {start|stop|restart|reload}"
esac


其它的可以参考下面2篇文章:

http://lixcto.blog.51cto.com/4834175/1539136 

http://www.phpddt.com/php/supervisor.html











本文转自 lirulei90 51CTO博客,原文链接:http://blog.51cto.com/lee90/1857179,如需转载请自行联系原作者
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
2月前
|
网络协议 Unix 应用服务中间件
Supervisor安装与配置
Supervisor安装与配置
|
2月前
|
监控 JavaScript Shell
如何安装和管理 Supervisor
如何安装和管理 Supervisor
34 0
|
5月前
|
监控 Ubuntu Unix
Supervisor使用详解
Supervisor使用详解
62 0
|
5月前
|
监控 应用服务中间件 nginx
Supervisor快速入门 | 使用Supervisor守护Nginx进程
Supervisor快速入门 | 使用Supervisor守护Nginx进程
169 0
supervisor 安装、配置、使用
supervisor 安装、配置、使用
730 0
supervisor的使用
supervisor的使用
98 0
|
JavaScript
supervisor安装
supervisor安装
114 0
|
jenkins 持续交付
jenkins通过supervisor配置守护进程
jenkins通过supervisor配置守护进程
220 0
|
运维 监控 Unix
Supervisord | 学习笔记
快速学习Supervisord,掌握如何进行服务的管理和配置,并引导学生主动完成服务的编写,为后续的运维工作打下基础
Supervisord | 学习笔记
|
Unix Shell 应用服务中间件
supervisor 使用
Supervisor是用Python开发的一套通用的进程管理程序,能将一个普通的命令行进程变为后台daemon,并监控进程状态,异常退出时能自动重启。它是通过fork/exec的方式把这些被管理的进程当作supervisor的子进程来启动,这样只要在supervisor的配置文件中,把要管理的进程的可执行文件的路径写进去即可。也实现当子进程挂掉的时候,父进程可以准确获取子进程挂掉的信息的,可以选择是否自己启动和报警。supervisor还提供了一个功能,可以为supervisord或者每个子进程,设置一个非root的user,这个user就可以管理它对应的进程。
336 0