登录
首页 >  文章 >  php教程

Supervisor进程重启日志怎么查?

时间:2026-03-17 21:12:44 488浏览 收藏

当Supervisor守护进程在宝塔面板中频繁重启时,问题往往隐藏在日志细节里——本文直击五大关键排查路径:从被守护进程的stdout/stderr实时报错、supervisord自身崩溃日志,到PHP禁用proc_open导致的启动秒退、INI配置中日志路径的误设,再到通过supervisorctl命令精准获取状态变化与重启统计,手把手教你快速定位根本原因,避免盲目重启浪费时间,让故障诊断从“玄学猜测”变为“证据驱动”。

宝塔面板中Supervisor管理器管理的进程频繁重启该如何查日志?

如果宝塔面板中Supervisor管理器所守护的进程出现频繁重启现象,则需立即定位异常触发点。日志是判断进程崩溃原因、启动失败或被强制终止的关键依据。以下是查阅相关日志的具体路径与操作方式:

一、查看被守护进程的标准输出与错误日志

每个通过Supervisor添加的守护进程,其运行时产生的标准输出(stdout)和标准错误(stderr)均被独立记录到指定日志文件中。这些日志直接反映进程内部报错、PHP函数缺失、路径错误或权限拒绝等实时问题。

1、登录宝塔面板,进入软件商店 → 找到并打开Supervisor进程管理器插件

2、在“守护进程管理”列表中,找到对应频繁重启的进程名称,点击其右侧的“日志”按钮

3、页面将自动加载该进程的 stdout 和 stderr 日志内容;若日志为空或无新内容,说明进程尚未成功启动或未产生输出。

4、若需手动确认日志物理路径,可参考格式:/www/server/panel/plugin/supervisor/log/进程名_序号.out.log/www/server/panel/plugin/supervisor/log/进程名_序号.err.log

二、查看Supervisor主服务自身运行日志

Supervisor主进程(supervisord)自身的日志记录了子进程状态变更、配置加载失败、权限校验错误及自动重启触发逻辑,对诊断“为何频繁重启”具有决定性作用。

1、在Supervisor插件界面,点击顶部导航栏中的“日志查看”模块

2、选择“Supervisor自身日志”选项卡,查看最近的系统级操作记录。

3、若该界面不可用或为空,可直接通过SSH执行命令访问:tail -n 50 /www/server/panel/plugin/supervisor/log/supervisord.log

4、重点关注包含 "FATAL""CRASHED""STARTING""BACKOFF""exited too quickly" 的行。

三、检查PHP禁用函数导致的启动失败日志

大量Supervisor守护进程(尤其是基于ThinkPHP、Laravel队列等PHP脚本)因PHP配置中禁用 proc_open 函数而无法初始化Process组件,从而在启动后数秒内退出,触发Supervisor反复拉起。

1、在Supervisor插件日志中搜索关键字:"The Process class relies on proc_open""proc_open is not available"

2、若命中,说明PHP环境存在函数禁用问题;此时需前往软件管理 → 对应PHP版本 → 禁用函数

3、在禁用函数列表中,找到并删除 proc_open,然后点击“重载配置”重启PHP服务

4、返回Supervisor插件,点击对应进程的“重启”按钮,观察日志是否不再出现上述错误。

四、通过SSH直接读取子进程配置文件中的日志路径定义

Supervisor为每个进程生成独立的INI配置文件,其中明确声明了stdout_logfile与stderr_logfile路径。当面板日志界面加载异常或路径被自定义修改时,需人工核对实际配置。

1、通过SSH连接服务器,执行:ls /www/server/panel/plugin/supervisor/profile/,列出全部进程配置文件。

2、使用cat命令查看目标进程配置,例如:cat /www/server/panel/plugin/supervisor/profile/myqueue.ini

3、在文件中查找以stdout_logfile=stderr_logfile=开头的行,确认日志绝对路径是否真实存在且可写。

4、若路径指向不存在的目录(如/data/logs/但该目录未创建),则需手动创建目录并赋权:mkdir -p /data/logs && chown www:www /data/logs

五、检查Supervisor子进程状态与重启计数

Supervisor内置状态统计机制会记录每个进程的启动次数、崩溃次数及最近一次退出代码。该信息不显示在面板日志中,但可通过命令行快速获取,用于判断是否达到最大重启阈值或存在持续性故障。

1、在SSH中执行:supervisorctl status,查看所有进程当前状态,注意状态列为STARTINGBACKOFFFATAL 的条目。

2、对特定进程执行:supervisorctl tail -f 进程名 stderr,实时追踪错误流输出。

3、若发现状态频繁在RUNNING与STOPPED间跳变,执行:supervisorctl pid 进程名,验证PID是否持续变化;若每次执行返回不同数字,证实确为高频重启。

4、进一步执行:supervisorctl info,查看Supervisor整体运行参数,特别关注 startsecs(最小稳定运行秒数)与 startretries(启动重试次数)是否被异常修改。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Supervisor进程重启日志怎么查?》文章吧,也可关注golang学习网公众号了解相关技术文章。

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>