Github 8.8K star,一款了不起的 Python 库--supervisor!
itomcoil 2025-08-05 18:53 5 浏览
大家好,今天为大家分享一个了不起的 Python 库 - supervisor。
Github地址:https://github.com/Supervisor/supervisor
Supervisor是一个功能强大的Python第三方库,专门用于在类Unix系统中管理和监控进程。该库采用客户端-服务器架构设计,提供了完整的进程生命周期管理功能,包括进程启动、停止、重启以及状态监控等核心能力。Supervisor的设计理念源于企业级应用对系统稳定性和可靠性的严格要求,能够确保关键业务进程在异常退出后自动重启,从而保障系统的持续运行。
安装
1、基础安装
Supervisor的安装过程需要考虑目标操作系统的特定要求。该库主要支持Linux和其他类Unix系统,不支持Windows平台。
# 通过pip安装Supervisor
pip install supervisor
# 在Ubuntu/Debian系统中通过apt安装
sudo apt-get install supervisor
# 在CentOS/RHEL系统中通过yum安装
sudo yum install supervisor
2、安装验证
安装完成后需要验证Supervisor的功能完整性和系统配置状态。验证过程包括检查主要组件的可用性、测试基本命令功能以及确认配置文件的正确性。
# 检查Supervisor版本信息
supervisord --version
# 生成默认配置文件
echo_supervisord_conf > /etc/supervisord.conf
# 启动Supervisor守护进程
sudo supervisord -c /etc/supervisord.conf
# 检查Supervisor状态
sudo supervisorctl status
主要特性
- 自动重启机制:监控进程状态并在异常退出时自动重启,确保服务连续性
- Web管理界面:提供直观的Web控制台进行进程管理和状态监控
- XML-RPC接口:支持远程管理和第三方系统集成
- 日志轮转管理:自动管理进程日志文件,防止磁盘空间溢出
- 进程组管理:支持将相关进程组织为逻辑组进行批量操作
- 资源限制控制:可设置进程的内存、CPU等资源使用限制
- 事件通知系统:支持进程状态变化事件的监听和处理
基本功能
1、配置文件管理
Supervisor的配置管理是其核心功能之一,通过标准的INI格式配置文件定义进程管理规则。配置文件采用分段结构,每个段落定义特定的功能模块或进程配置。合理的配置管理不仅能够确保进程的正确启动和运行,还能够提供灵活的管理策略和监控机制。
# 创建基础配置文件 /etc/supervisord.conf
[unix_http_server]
file=/var/run/supervisor.sock
chmod=0700
[supervisord]
logfile=/var/log/supervisor/supervisord.log
pidfile=/var/run/supervisord.pid
childlogdir=/var/log/supervisor
[rpcinterface:supervisor]
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
[supervisorctl]
serverurl=unix:///var/run/supervisor.sock
# 示例应用程序配置
[program:webapp]
command=/usr/bin/python3 /opt/webapp/app.py
directory=/opt/webapp
user=webapp
autostart=true
autorestart=true
redirect_stderr=true
stdout_logfile=/var/log/supervisor/webapp.log
2、进程启动和管理
Supervisor提供了完整的进程生命周期管理功能,包括进程的启动、停止、重启以及状态查询等操作。
# 创建示例Web应用程序 /opt/webapp/app.py
import time
import logging
from http.server import HTTPServer, BaseHTTPRequestHandler
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
class RequestHandler(BaseHTTPRequestHandler):
def do_GET(self):
self.send_response(200)
self.send_header('Content-type', 'text/html')
self.end_headers()
response_content = f"""
<html>
<body>
<h1>Supervisor管理的应用</h1>
<p>当前时间: {time.strftime('%Y-%m-%d %H:%M:%S')}</p>
</body>
</html>
"""
self.wfile.write(response_content.encode('utf-8'))
logging.info(f"处理请求来自: {self.client_address[0]}")
def main():
server = HTTPServer(('', 8090), RequestHandler)
logging.info("Web服务器启动在端口 8090")
server.serve_forever()
if __name__ == '__main__':
main()
# 重新加载配置并启动进程
sudo supervisorctl reread
sudo supervisorctl update
sudo supervisorctl start webapp
sudo supervisorctl status webapp
3、日志监控和管理
Supervisor内置了完善的日志管理系统,能够自动收集和管理被监控进程的输出日志。日志管理功能包括日志轮转、大小限制、备份保留等机制,确保系统在长期运行过程中不会因为日志文件过大而影响性能。
# 详细的日志配置示例
[program:data_processor]
command=/usr/bin/python3 /opt/tasks/processor.py
directory=/opt/tasks
user=tasks
autostart=true
autorestart=true
redirect_stderr=true
stdout_logfile=/var/log/supervisor/processor.log
stdout_logfile_maxbytes=50MB
stdout_logfile_backups=10
stderr_logfile=/var/log/supervisor/processor_error.log
stderr_logfile_maxbytes=10MB
stderr_logfile_backups=5
高级功能
1、进程组管理
Supervisor的进程组功能允许将相关的进程组织成逻辑单元进行统一管理。
# 微服务架构进程组配置示例
[program:api_gateway]
command=/usr/bin/python3 /opt/services/gateway/main.py
directory=/opt/services/gateway
user=services
autostart=true
autorestart=true
priority=100
[program:user_service]
command=/usr/bin/python3 /opt/services/user/main.py
directory=/opt/services/user
user=services
autostart=true
autorestart=true
priority=200
[group:microservices]
programs=api_gateway,user_service
priority=100
2、事件监听和通知
Supervisor提供了强大的事件系统,允许开发者编写自定义的事件监听器来响应进程状态变化。
# 事件监听器示例
import sys
import logging
from supervisor.childutils import listener
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger('ProcessMonitor')
def handle_event(headers, payload):
process_name = headers['processname']
from_state = headers['from_state']
if headers.get('expected') == 'FATAL':
logger.error(f"进程 {process_name} 启动失败: {from_state}")
# 发送告警通知
elif from_state == 'RUNNING':
logger.warning(f"进程 {process_name} 异常退出")
def main():
while True:
headers, payload = listener.wait(sys.stdin, sys.stdout)
if headers['eventname'].startswith('PROCESS_STATE'):
handle_event(headers, payload)
listener.ok(sys.stdout)
if __name__ == '__main__':
main()
总结
Supervisor作为Python生态系统中的企业级进程管理解决方案,通过其完善的功能特性和稳定的架构设计,为现代软件系统的运维管理提供了坚实的基础支撑。该库的核心价值体现在其对系统稳定性和可管理性的双重保障,使运维团队能够构建可靠的服务运行环境。通过统一的配置管理、灵活的进程控制和完善的监控机制,Supervisor有效降低了复杂系统的运维复杂度,提升了服务的可用性和可靠性。
相关推荐
- selenium(WEB自动化工具)
-
定义解释Selenium是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。支持的浏览器包括IE(7,8,9,10,11),MozillaF...
- 开发利器丨如何使用ELK设计微服务中的日志收集方案?
-
【摘要】微服务各个组件的相关实践会涉及到工具,本文将会介绍微服务日常开发的一些利器,这些工具帮助我们构建更加健壮的微服务系统,并帮助排查解决微服务系统中的问题与性能瓶颈等。我们将重点介绍微服务架构中...
- 高并发系统设计:应对每秒数万QPS的架构策略
-
当面试官问及"如何应对每秒几万QPS(QueriesPerSecond)"时,大概率是想知道你对高并发系统设计的理解有多少。本文将深入探讨从基础设施到应用层面的解决方案。01、理解...
- 2025 年每个 JavaScript 开发者都应该了解的功能
-
大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发。1.Iteratorhelpers开发者...
- JavaScript Array 对象
-
Array对象Array对象用于在变量中存储多个值:varcars=["Saab","Volvo","BMW"];第一个数组元素的索引值为0,第二个索引值为1,以此类推。更多有...
- Gemini 2.5编程全球霸榜,谷歌重回AI王座,神秘模型曝光,奥特曼迎战
-
刚刚,Gemini2.5Pro编程登顶,6美元性价比碾压Claude3.7Sonnet。不仅如此,谷歌还暗藏着更强的编程模型Dragontail,这次是要彻底翻盘了。谷歌,彻底打了一场漂亮的翻...
- 动力节点最新JavaScript教程(高级篇),深入学习JavaScript
-
JavaScript是一种运行在浏览器中的解释型编程语言,它的解释器被称为JavaScript引擎,是浏览器的一部分,JavaScript广泛用于浏览器客户端编程,通常JavaScript脚本是通过嵌...
- 一文看懂Kiro,其 Spec工作流秒杀Cursor,可移植至Claude Code
-
当Cursor的“即兴编程”开始拖累项目质量,AWS新晋IDEKiro以Spec工作流打出“先规范后编码”的系统工程思维:需求-设计-任务三件套一次生成,文档与代码同步落地,复杂项目不...
- 「晚安·好梦」努力只能及格,拼命才能优秀
-
欢迎光临,浏览之前点击上面的音乐放松一下心情吧!喜欢的话给小编一个关注呀!Effortscanonlypass,anddesperatelycanbeexcellent.努力只能及格...
- JavaScript 中 some 与 every 方法的区别是什么?
-
大家好,很高兴又见面了,我是姜茶的编程笔记,我们一起学习前端相关领域技术,共同进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力在JavaScript中,Array.protot...
- 10个高效的Python爬虫框架,你用过几个?
-
小型爬虫需求,requests库+bs4库就能解决;大型爬虫数据,尤其涉及异步抓取、内容管理及后续扩展等功能时,就需要用到爬虫框架了。下面介绍了10个爬虫框架,大家可以学习使用!1.Scrapysc...
- 12个高效的Python爬虫框架,你用过几个?
-
实现爬虫技术的编程环境有很多种,Java、Python、C++等都可以用来爬虫。但很多人选择Python来写爬虫,为什么呢?因为Python确实很适合做爬虫,丰富的第三方库十分强大,简单几行代码便可实...
- pip3 install pyspider报错问题解决
-
运行如下命令报错:>>>pip3installpyspider观察上面的报错问题,需要安装pycurl。是到这个网址:http://www.lfd.uci.edu/~gohlke...
- PySpider框架的使用
-
PysiderPysider是一个国人用Python编写的、带有强大的WebUI的网络爬虫系统,它支持多种数据库、任务监控、项目管理、结果查看、URL去重等强大的功能。安装pip3inst...
- 「机器学习」神经网络的激活函数、并通过python实现激活函数
-
神经网络的激活函数、并通过python实现whatis激活函数感知机的网络结构如下:左图中,偏置b没有被画出来,如果要表示出b,可以像右图那样做。用数学式来表示感知机:上面这个数学式子可以被改写:...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)