Linux进程守护supervisor:零基础用 S

零基础用 Supervisor 守护 Linux 进程:从安装到配置完整教程


在服务器运维中,很多程序需要长期运行,一旦崩溃或异常退出就可能导致服务中断。Linux进程守护supervisor 正是解决这个问题的利器——它能监控并自动重启你的程序。

本文将一步步带你完成安装、配置和验证,让零基础用户也能轻松上手。


安装 Supervisor:两种常用方式


推荐使用系统包管理器安装,最稳定且自动配置服务:



  • Ubuntu/Debiansudo apt install supervisor

  • CentOS/RHELsudo yum install supervisorsudo dnf install supervisor


安装后启动服务并设置开机自启:


sudo systemctl start supervisord
sudo systemctl enable supervisord

如果你需要最新版本或包管理器不可用,也可以用 pip 安装:


pip install supervisor
echo_supervisord_conf > /etc/supervisord.conf

注意:pip 方式需手动生成默认配置文件,并自行启动 supervisord,适合进阶用户。

编写程序配置文件


Supervisor 的主配置文件一般在 /etc/supervisor/supervisord.conf

但更推荐在 /etc/supervisor/conf.d/ 下为每个程序创建独立的 .conf 文件,

方便管理。


假设你要守护一个 Python 脚本 /home/user/myapp.py,实现异常退出后自动重启。

/etc/supervisor/conf.d/ 下创建 myapp.conf


[program:myapp]
command=python /home/user/myapp.py
directory=/home/user
user=root
autostart=true
autorestart=true
stderr_logfile=/var/log/myapp_err.log
stdout_logfile=/var/log/myapp_out.log

各字段含义:



  • command:程序启动命令(尽量使用绝对路径)

  • directory:工作目录

  • user:运行用户,如果需高权限可设为 root(注意安全)

  • autostart:是否随 Supervisor 自动启动

  • autorestart:异常退出后自动重启,设为 true 才生效

  • stderr_logfile / stdout_logfile:错误和标准输出日志路径,便于排错


更新配置并启动程序


写好配置文件后,让 Supervisor 重新读取并应用:


sudo supervisorctl reread   # 检查并加载新配置
sudo supervisorctl update # 应用变更

这两个命令顺序执行即可,无需重启 Supervisor 服务。


查看所有程序状态:


sudo supervisorctl status

运行效果会显示 myapp RUNNINGFATAL 等状态。


控制单个程序:


sudo supervisorctl start myapp
sudo supervisorctl stop myapp
sudo supervisorctl restart myapp

避坑指南:常见问题与解决方法



  1. 程序启动后状态为 FATAL:查看日志文件(配置中指定的日志路径),定位具体报错,如缺少环境变量或权限不足。

  2. 权限问题:确保 directory 和日志目录对配置的 user 可读写。如果使用 user=root,则需注意安全风险。

  3. 配置文件语法错误:执行 sudo supervisorctl reread 时会提示错误位置,修正后重新加载。

  4. 环境变量缺失:程序依赖的环境变量(如 PATHHOME)可在配置中通过 environment 显式设置:


   environment=HOME="/home/user",PATH="/usr/local/bin:%(ENV_PATH)s"


  1. 开机自启未生效:确认开机自启用 sudo systemctl enable supervisord,并检查服务状态。


效果验证:确保进程守护生效


完成配置后,模拟程序崩溃来验证自动重启:



  1. 运行 sudo supervisorctl status 确认程序为 RUNNING

  2. 查找进程 PID:ps aux | grep myapp(或直接使用 pgrep -f myapp)。

  3. 强制终止进程:sudo kill -9 [PID]

  4. 等待几秒,再次执行 sudo supervisorctl status,观察状态是否为 RUNNING

  5. 查看 /var/log/myapp_out.log/var/log/myapp_err.log,应能看到重启记录。


如果自动重启成功,说明 Linux进程守护supervisor 已正确保护你的应用。


总结


通过以上步骤,你已经掌握了 Supervisor 的基本安装、配置和验证方法。

记住核心命令 rereadupdate 的配合使用,并且善用日志分析问题。

如果你正在部署需要长期运行的服务,建议先按本文流程操作,再根据实际环境微调,遇到异常时优先查看状态和日志,绝大多数问题都能快速定位。

分享到:
上一篇
WordPress故障排查指南
下一篇
Docker容器数据卷持久化教程
1
系统公告

泽御云五一特惠活动🔥

泽御云持证合规运营,资质齐全可查,长久稳定! 五一限时多重福利同步开启: ✅ 香港 2 核 2G 云服务器超值拼团,低价入手团长免费 ✅ 4 核 4G 多机房年付拼团,性价比拉满 ✅ 内蒙古新区限时 7 折(zeyuyunnmg)特惠,专属优惠码锁价续费 ✅ 全站通用 75 折优惠,老用户充值享专属赠金 官方站点:zeyuyun.com 合规资质齐全|售后有保障|活动限时错过不再有
服务中心
客服
在线客服
24小时为您服务
咨询
联系我们
联系我们,为您的业务提供专属服务。
24/7 技术支持
如果您遇到寻求进一步的帮助,请过工单与我们进行联系。
24/7 即时支持
泽御云
售前客服
泽御云
泽御云
售后客服
泽御云
技术支持
评价
您对当前页面的整体感受是否满意?
😞
非常不满意
😕
不满意
😐
一般
🙂
满意
😊
非常满意