当前位置:首页 > 文章列表 > 文章 > php教程 > PHP 开发人员主管指南

PHP 开发人员主管指南

2025-01-21 17:28:06 0浏览 收藏

哈喽!今天心血来潮给大家带来了《PHP 开发人员主管指南》,想必大家应该对文章都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到,若是你正在学习文章,千万别错过这篇文章~希望能帮助到你!

PHP 开发人员主管指南

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

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

什么是Supervisor?

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

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

Supervisor尤其适用于以下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常用配置选项及其示例:

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都能确保其可靠性和易用性。

以上就是《PHP 开发人员主管指南》的详细内容,更多关于的资料请关注golang学习网公众号!

CentOS 7如何安装redisCentOS 7如何安装redis
上一篇
CentOS 7如何安装redis
宝塔如何关闭https强制跳转(http/https共存)
下一篇
宝塔如何关闭https强制跳转(http/https共存)
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    6170次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    6574次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    6384次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    8348次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    6994次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码