0

0

PHP 开发人员主管指南

霞舞

霞舞

发布时间:2025-01-20 14:49:51

|

1101人浏览过

|

来源于php中文网

原创

php 开发人员主管指南

Supervisor是一个功能强大的进程控制系统,广泛应用于后台进程管理。对于PHP开发者而言,经常需要处理长时间运行的进程、队列任务和其他后台作业,Supervisor能够简化这一过程,确保进程持续运行,并在进程异常终止时自动重启,同时提供便捷的监控和管理功能。

本文将指导您如何配置和使用Supervisor管理PHP应用程序,并讲解如何利用其各项功能选项优化效率。

什么是Supervisor?

Supervisor是一个进程控制系统,主要功能包括:

  • 自动重启崩溃的进程。
  • 提供统一的日志记录机制。
  • 通过命令行或Web界面进行进程控制。

Supervisor尤其适用于以下PHP应用场景:

立即学习PHP免费学习笔记(深入)”;

  • Laravel后台任务队列。
  • 长时间运行的脚本,例如WebSocket服务器。
  • 定时任务(类似cron)。

安装Supervisor

Ubuntu/Debian系统

sudo apt update
sudo apt install supervisor

CentOS/Red Hat系统

sudo yum install epel-release
sudo yum install supervisor

安装完成后,启动并启用Supervisor服务:

sudo systemctl start supervisord
sudo systemctl enable supervisord

Supervisor基础配置

Supervisor使用配置文件(通常位于/etc/supervisor/conf.d/目录下)管理各个程序。

基本配置示例

以下是一个管理PHP工作进程的简单配置文件示例。在/etc/supervisor/conf.d/目录下创建一个名为my_php_worker.conf的文件,并添加以下内容:

[program:my_php_worker]
command=php /path/to/worker.php
autostart=true
autorestart=true
stderr_logfile=/var/log/my_php_worker.err.log
stdout_logfile=/var/log/my_php_worker.out.log

--tries=3选项指定进程在判定任务失败前最多重试3次。

应用配置更改:

sudo supervisorctl reread
sudo supervisorctl update
sudo supervisorctl start my_php_worker:*

Supervisor常用配置选项

以下是Supervisor常用配置选项及其示例:

威客
威客

PHP威客系统威客贰系统是国内领先的威客网站内容管理系统,基于PHP+Mysql架构开发。整合UCHOME系统,系统内容模块由:威客悬赏,招标任务,人才库,人才,招聘,新闻资讯,在线支付,发贴推广,案例示范等多种功能组成。 威客贰系统独创的单人悬赏、 多人悬赏 、计件悬赏 、 定金招标、 本地招标为核心任务模式。超强的发贴推广可以分配到不同的任务模式不同的会员等级有不同的提成费用,根据网站自身需要

下载

1. command: 指定要执行的命令。 示例:

command=php /path/to/worker.php

2. autostart: Supervisor启动时是否自动启动程序。 值: true (默认), false 示例:

autostart=true

3. autorestart: 是否自动重启程序。 值: true, false, unexpected 示例:

autorestart=unexpected

4. startsecs: 进程必须保持运行的时间(秒),才能被视为成功启动。 默认值: 1 示例:

startsecs=5

5. startretries: 进程被标记为失败前允许的重启次数。 默认值: 3 示例:

startretries=5

6. exitcodes: 不会触发重启的可接受退出代码列表。 默认值: 0,2 示例:

exitcodes=0,1

7. stopwaitsecs: 发送停止信号后,强制终止进程前等待的时间(秒)。 默认值: 10 示例:

stopwaitsecs=20

8. redirect_stderr: 将标准错误输出重定向到与标准输出相同的日志文件。 值: true, false (默认) 示例:

redirect_stderr=true

9. stdout_logfile / stderr_logfile: 标准输出和标准错误日志文件路径。 示例:

stdout_logfile=/var/log/my_program.out.log
stderr_logfile=/var/log/my_program.err.log

10. stdout_logfile_maxbytes / stderr_logfile_maxbytes: 日志文件轮转前允许的最大文件大小。 默认值: 50MB 示例:

stdout_logfile_maxbytes=10MB
stderr_logfile_maxbytes=5MB

11. stdout_logfile_backups / stderr_logfile_backups: 要保留的轮转日志文件数量。 默认值: 10 示例:

stdout_logfile_backups=3
stderr_logfile_backups=3

12. user: 运行程序的用户。 示例:

user=www-data

13. environment: 定义程序的环境变量。 示例:

environment=app_env="production",db_host="localhost"

14. priority: 控制程序启动顺序,数值越小越先启动。 默认值: 999 示例:

priority=100

15. directory: 指定程序的工作目录。 示例:

directory=/path/to/your/app

16. stopasgroup: 向程序及其子进程发送停止信号。 值: true, false (默认) 示例:

stopasgroup=true

17. killasgroup: 如果程序及其子进程在stopwaitsecs后仍未停止,则向它们发送终止信号。 值: true, false (默认) 示例:

killasgroup=true

PHP开发者应用场景

1. 管理Laravel队列

Laravel的queue:work命令用于处理队列任务。Supervisor可以确保这些工作进程持续运行。

配置示例:

[program:laravel_queue_worker]
command=php /path/to/artisan queue:work --tries=3
autostart=true
autorestart=true
user=www-data
stderr_logfile=/var/log/laravel_queue_worker.err.log
stdout_logfile=/var/log/laravel_queue_worker.out.log

2. 运行定时任务

对于需要定期执行的脚本,Supervisor比cron更可靠。

配置示例:

[program:send_reminders]
command=php /path/to/send_reminders.php
autostart=true
autorestart=true
stderr_logfile=/var/log/send_reminders.err.log
stdout_logfile=/var/log/send_reminders.out.log

3. 长时间运行的脚本

使用Supervisor管理WebSocket服务器或其他持久化运行的脚本。

配置示例:

[program:websocket_server]
command=php /path/to/websocket_server.php
autostart=true
autorestart=true
stderr_logfile=/var/log/websocket_server.err.log
stdout_logfile=/var/log/websocket_server.out.log

设置Supervisor在系统启动时自动启动

要确保Supervisor在系统启动时自动运行,请执行以下步骤:

1. 启用Supervisor服务在系统启动时自动启动:

sudo systemctl enable supervisord

2. 启动Supervisor服务(如果尚未运行):

sudo systemctl start supervisord

最佳实践

  • 使用具有描述性的程序名称。
  • 配置stdout_logfile_maxbytesstdout_logfile_backups实现日志轮转。
  • 使用environment传递环境变量。

结论

Supervisor是PHP开发者管理后台任务的强大工具。本文介绍了Supervisor的安装、配置以及在实际应用中的案例。无论您是运行Laravel队列、定时任务还是长时间运行的进程,Supervisor都能确保其可靠性和易用性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

320

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

278

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

372

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

374

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

85

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

65

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

68

2025.08.05

Golang WebSocket与实时通信开发
Golang WebSocket与实时通信开发

本专题系统讲解 Golang 在 WebSocket 开发中的应用,涵盖 WebSocket 协议、连接管理、消息推送、心跳机制、群聊功能与广播系统的实现。通过构建实际的聊天应用或实时数据推送系统,帮助开发者掌握 如何使用 Golang 构建高效、可靠的实时通信系统,提高并发处理与系统的可扩展性。

22

2025.12.22

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Laravel---API接口
Laravel---API接口

共7课时 | 0.6万人学习

PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

PHP面向对象基础课程(更新中)
PHP面向对象基础课程(更新中)

共12课时 | 0.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号