百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

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,可以像右图那样做。用数学式来表示感知机:上面这个数学式子可以被改写:...