设为首页 收藏本站
查看: 897|回复: 0

[经验分享] ELK 服务端程序启停自动管理工具之supervisor

[复制链接]

尚未签到

发表于 2019-1-28 09:53:40 | 显示全部楼层 |阅读模式
一,说说前因后果
  说说痛点,elasticsearch,kafka,zookeeper,kibana,elasticsearch-head,logstash,logstash是需要经常重启的,你上了点过滤规则或者修改点啥的,每次都尼玛杀进程,再nohup ,还看不到日志,这太不符合人性了,人性的优点之一就是懒惰。打开web 界面,点一下鼠标解决问题岂不是棒棒哒,还能通过web 界面看看后台日志,perfect!子曰:“工欲善其事,必先利其器。” 开搞!
supervisor运行的系统:centos 7
supervisor version:3.3.4

二,Supervisor 简介及优势
  Supervisor 简介:
Supervisor is a client/server system that allows its users to monitor and control a number of processes on UNIX-like operating systems.
Supervisor 是个c/s 架构的系统,它允许用户在类Unix 系统上管理和监控一定数量的程序运行;
你有没有很多源码安装的程序?你怎么启动这些程序?nohup 是不是?还是screen?还是& 后台?还是自练神功,写一堆启动脚本呢?即使是这样你的程序因为bug或者其它原因down了呢?还是需要你手动去启动是不?
当你了解supervisor之后你就知道,什么叫磨刀不误砍柴工了!supervisor 有哪几个niubility的功能呢?
1,程序启动,停止,重启统一管理,提供web和命令行方式;
2,程序down掉自动拉起;
3,可以指定启动用户,安全方面杠杠滴;
4,可以定义group 重启,和启动;
5,web 界面管理非常方便,毕竟点点鼠标就搞定了的事情,谁不愿意呢?

三,正式开搞
  #supervisor 是用Python写的程序,所以可以通过easy_install 来安装,也可以用pip 来安装,这个看自己了;
#我习惯用pip 装东西,所以用easy_install 安装pip
easy_install pip
#之后通过pip 安装supervisor
pip install supervisor
  #为supervisor创建工作目录与配置文件目录并且赋予该目录755 的权限;
mkdir -m 755 -p /etc/supervisor/conf.d
  #通过supervisor 提供的 echo_supervisord_conf 命令生成默认配置文件、
echo_supervisord_conf > /etc/supervisor/supervisord.conf
#通过cat 命令查看配置文件是否生成;

cat /etc/supervisor/supervisord.conf |grep -v "^;" |grep -v "^$"
[unix_http_server]
file=/tmp/supervisor.sock   ; the path to the socket file
[inet_http_server]         ; inet (TCP) server disabled by default  #是否开启web 管理界面
port=ip:9001        ; ip_address:port specifier, *:port for all iface  #web 访问端口;
username=user          ; default is no username (open server)  #web 界面访问用户名;
password=password              ; default is no password (open server)  #web 界面访问密码;
[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=10           ; # of main logfile backups; 0 means none, default 10  #日志滚动多少次
loglevel=info                ; log level; default info; others: debug,warn,trace   #log 级别
pidfile=/tmp/supervisord.pid ; supervisord pidfile; default supervisord.pid  #pid 文件
nodaemon=false               ; start in foreground if true; default false  #是否在前台启动,默认是false,即以 daemon 的方式启动
minfds=1024                  ; min. avail startup file descriptors; default 1024 #可以打开的文件描述符的最小值,默认 1024
minprocs=200                 ; min. avail process descriptors;default 200       #可以打开的进程数的最小值,默认 200
[rpcinterface:supervisor]
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
[supervisorctl]
serverurl=unix:///tmp/supervisor.sock ; use a unix:// URL  for a unix socket    #通过UNIX socket连接supervisord,路径与unix_http_server部分的file一致
[include]
files =/etc/supervisor/conf.d/*.conf  #引入额外的配置文件
  #放到/etc/supervisor/conf.d/  的xxx.conf配置文件

[program:logstash-pack]   #是被管理的进程配置参数,xx是进程的名称,通过supervisorctl 管理程序的时候和web 界面使用
command = /usr/local/logstash/bin/logstash -f /usr/local/logstash/config/logstashx.conf
[program:kafka]
command = /usr/local/kafka/bin/kafka-server-start.sh /usr/local/kafka/config/server.properties
[program:kibana]
command = /usr/local/kibana/bin/kibana
[program:elasticsearch]
command = /usr/local/elasticsearch/bin/elasticsearch
autostart = true              # 被管理程序在supervisord启动的时候也自动启动
autorestart = true           #程序退出后自动重启,可选值:[unexpected,true,false],默认为unexpected,表示进程意外杀死后才重启
startsecs = 5                   #启动5秒后没有异常退出,就表示进程正常启动了,默认为1秒
startretries = 3                 #启动失败重试几次,默认3次
user = elk                        #启动用户这个是为了安全起见
redirect_stderr = true       #把stderr重定向到stdout,默认false
stdout_logfile=/data/logs/elk/logstash-shipper-std.log   #stdout 日志文件大小,默认50MB  需要手动创建目录,并且赋予elk的权限
stderr_logfile=/data/logs/elk/logstash-shipper-err.log     #stdout 日志文件备份数,默认是10 需要手动创建目录,并且赋予elk的权限
四,启动验证supervisor
  #配置文件搞定了,可以启动supervisor了
supervisord -c /etc/supervisor/supervisord.conf
  #supervisor 的管理是通过supervisorctl 管理,可以通过命令带参数形式例如:suervervisorctl  shutdown ,也可以通过进入交互模式进行管理,例如supervisorctl 回车,之后执行命令即可;
#参考启动的程序
supervisor  status
第一行是自定义的名字;  第二个是运行状态,第三是pid ,第三行是启动时间

#关闭supervisor
supervisorctl shutdown
#重新载入supervisor,重新载入supervisor,在这里相当于重启supervisor服务,里面的服务也会跟着重新启动
supervisor reload
#添加/删除 要管理服务,当你修改了配置文件,可以直接通过update 方式升级即可
supervisor update
  #通过命令方式启动所有服务或者单个服务
supervisorctl  start all
supervisorctl  start  service_name
#关闭服务
supervisorctl stop all
supervisorctl  stop  service_name
#重启所有服务或者单个服务
supervisorctl  restart all
supervistorctl restart service_name
看图说话web 管理界面:





运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-668556-1-1.html 上篇帖子: elk 收藏 下篇帖子: ELK5
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表