热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:ELK服务端程序启停自动管理工具之supervisor

说说痛点,elasticsearch,kafka,zookeeper,kibana,elasticsearch-head,logstash,logstash

说说痛点,elasticsearch,kafka,zookeeper,kibana,elasticsearch-head,logstash,logstash是需要经常重启的,你上了点过滤规则或者修改点啥的,每次都尼玛杀进程,再nohup ,还看不到日志,这太不符合人性了,人性的优点之一就是懒惰。打开web 界面,点一下鼠标解决问题岂不是棒棒哒,还能通过web 界面看看后台日志,perfect!子曰:“工欲善其事,必先利其器。” 开搞!

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 #引入额外的配置文件

#放到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了
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 管理界面:
技术分享图片


推荐阅读
  • Docker安全策略与管理
    本文探讨了Docker的安全挑战、核心安全特性及其管理策略,旨在帮助读者深入理解Docker安全机制,并提供实用的安全管理建议。 ... [详细]
  • 分布式计算助力链力实现毫秒级安全响应,确保100%数据准确性
    随着分布式计算技术的发展,其在数据存储、文件传输、在线视频、社交平台及去中心化金融等多个领域的应用日益广泛。国际知名企业如Firefox、Google、Opera、Netflix、OpenBazaar等均已采用该技术,推动了技术创新和服务升级。 ... [详细]
  • 本文详细介绍了PHP中的几种超全局变量,包括$GLOBAL、$_SERVER、$_POST、$_GET等,并探讨了AJAX的工作原理及其优缺点。通过具体示例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 汇总了2023年7月7日最新的网络安全新闻和技术更新,包括最新的漏洞披露、工具发布及安全事件。 ... [详细]
  • 本文探讨了使用Python实现监控信息收集的方法,涵盖从基础的日志记录到复杂的系统运维解决方案,旨在帮助开发者和运维人员提升工作效率。 ... [详细]
  • Java虚拟机及其发展历程
    Java虚拟机(JVM)是每个Java开发者日常工作中不可或缺的一部分,但其背后的运作机制却往往显得神秘莫测。本文将探讨Java及其虚拟机的发展历程,帮助读者深入了解这一关键技术。 ... [详细]
  • Asynchronous JavaScript and XML (AJAX) 的流行很大程度上得益于 Google 在其产品如 Google Suggest 和 Google Maps 中的应用。本文将深入探讨 AJAX 在 .NET 环境下的工作原理及其实现方法。 ... [详细]
  • 本文详细介绍了如何在CentOS 6.5系统上安装和配置Redis 3.0.6,包括必要的环境准备、软件包下载、编译安装及基本功能测试。 ... [详细]
  • 本文详细介绍了如何在ARM架构的目标设备上部署SSH服务端,包括必要的软件包下载、交叉编译过程以及最终的服务配置与测试。适合嵌入式开发人员和系统集成工程师参考。 ... [详细]
  • 大数据领域的职业路径与角色解析
    本文将深入探讨大数据领域的各种职业和工作角色,帮助读者全面了解大数据行业的需求、市场趋势,以及从入门到高级专业人士的职业发展路径。文章还将详细介绍不同公司对大数据人才的需求,并解析各岗位的具体职责、所需技能和经验。 ... [详细]
  • C/C++ 应用程序的安装与卸载解决方案
    本文介绍了如何使用Inno Setup来创建C/C++应用程序的安装程序,包括自动检测并安装所需的运行库,确保应用能够顺利安装和卸载。 ... [详细]
  • MVC模式下的电子取证技术初探
    本文探讨了在MVC(模型-视图-控制器)架构下进行电子取证的技术方法,通过实际案例分析,提供了详细的取证步骤和技术要点。 ... [详细]
  • 本文介绍了Tomcat的基本操作,包括启动、关闭及首次访问的方法,并详细讲解了如何在IDEA中创建Web项目,配置Servlet及其映射,以及如何将项目部署到Tomcat。 ... [详细]
  • 美团安全响应中心推出全新配送业务测试活动,带来双重福利,邀您共同参与! ... [详细]
  • CentOS下ProFTPD的安装与配置指南
    本文详细介绍在CentOS操作系统上安装和配置ProFTPD服务的方法,包括基本配置、安全设置及高级功能的启用。 ... [详细]
author-avatar
迷人的哈喽柯柯_458
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有