需立即定位Supervisor守护进程频繁重启的异常触发点,主要通过五类日志排查:一、查看进程stdout/stderr日志;二、检查supervisord自身日志;三、确认PHP是否禁用proc_open;四、核对INI配置中日志路径;五、用supervisorctl命令查状态与重启统计。

如果宝塔面板中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,查看所有进程当前状态,注意状态列为STARTING、BACKOFF、FATAL 的条目。
2、对特定进程执行:supervisorctl tail -f 进程名 stderr,实时追踪错误流输出。
3、若发现状态频繁在RUNNING与STOPPED间跳变,执行:supervisorctl pid 进程名,验证PID是否持续变化;若每次执行返回不同数字,证实确为高频重启。
4、进一步执行:supervisorctl info,查看Supervisor整体运行参数,特别关注 startsecs(最小稳定运行秒数)与 startretries(启动重试次数)是否被异常修改。










