使用 Supervisor 管理 Laravel 队列进程

(原文链接:https://blog.tanteng.me/2017/01/supervisor...

Supervisor 是一个 Python 写的进程管理工具,有时一个进程需要在后台运行,并且意外挂掉后能够自动重启,就需要这么一个管理进程的工具。在 Laravel 开发中,也经常使用到队列监听,可以配合 Supervisor 来管理 Laravel 队列进程。

Supervisor的安装

  1. 使用 pip 工具进行安装:
    sudo pip install supervisor
  2. Ubuntu 系统使用 apt-get
    sudo apt-get install supervisor

    还有其他的安装方式,请见官网(http://supervisord.org/

Supervisor的配置

运行这个命令可以生成一个默认的配置文件:

echo_supervisord_conf > /etc/supervisord.conf

生成成功后,打开编辑这个文件,把最后的 include 块的注释打开,并修改如下:

[include]
files = /etc/supervisor/*.conf

新增的 Supervisor 配置文件放在 /etc/supervisor 目录下,并且以 conf 结尾。

这时我们使用新的配置文件来启动 Supervisor:

supervisord -c /etc/supervisord.conf

如果提示已经有进程在运行,那么先 kill 掉它。

使用Supervisor管理Laravel队列进程

我们使用 Laravel 队列,会用到 php artisan queue:work 命令,让它监听队列,我们可以通过 nohup 方式让它在后台运行,但是进程如果意外中断是不会自动重启的,所以使用 Supervisor 来监控进程是个很好的方式。

首先在 /etc/supervisor 目录下新增一个 Supervisor 的配置文件,如下:

[program:laravel-worker]
process_name=%(program_name)s_%(process_num)02d
command=php /usr/share/nginx/html/tanteng.me/artisan queue:work --tries=3
autostart=true
autorestart=true
user=vagrant
numprocs=8
redirect_stderr=true
stdout_logfile=/var/log/supervisor/laravel-queue.log

这里 user 填写网站运行进程的用户,如 vagrant,numprocs 表示启动多少个进程来监听 Laravel 队列。

一切就绪后,我们使用如下命令就可以启动队列进程的监听了:

sudo supervisorctl reread

sudo supervisorctl update

sudo supervisorctl start laravel-worker:*

但是在这一步,发生了错误,提示如下:

laravel-worker:laravel-worker_00: ERROR (spawn error)
laravel-worker:laravel-worker_01: ERROR (spawn error)
laravel-worker:laravel-worker_02: ERROR (spawn error)
laravel-worker:laravel-worker_03: ERROR (spawn error)
laravel-worker:laravel-worker_04: ERROR (spawn error)
laravel-worker:laravel-worker_05: ERROR (spawn error)
laravel-worker:laravel-worker_06: ERROR (spawn error)
laravel-worker:laravel-worker_07: ERROR (spawn error)

经过一番折腾,解决方法是,把 Supervisor 的日志文件,和新增的队列配置文件中的日志文件,用 chown 把用户和组设置为正确的,如本例是 chown vagrant:vagrant file_name,另外把日志文件权限设置为 777.

再次经过上述步骤,成功开启进程管理:

laravel-worker:laravel-worker_00: started
laravel-worker:laravel-worker_01: started
laravel-worker:laravel-worker_02: started
laravel-worker:laravel-worker_03: started
laravel-worker:laravel-worker_04: started
laravel-worker:laravel-worker_05: started
laravel-worker:laravel-worker_06: started
laravel-worker:laravel-worker_07: started

可以看到 Laravel 队列开始正常运行了,这里值得注意的是,如果 Laravel 处理队列的代码更改了,需要重启 Supervisor 的队列管理才能生效。

本帖已被设为精华帖!
本帖由 Summer 于 7年前 加精
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 7
xingchen

这个玩意需要python 跑不起来的运行如下
wget --no-check-certificate https://bootstrap.pypa.io/ez_setup.py -O - | sudo python

5年前 评论

为何,我的直接运行命令可以,加入supervisor后报语法错:PHP Parse error: syntax error, unexpected '=' in /home/mall/project/api.project.com/vendor/illuminate/config/Repository.php on line 68

5年前 评论

sudo supervisorctl start laravel-worker:* ,无输出, status 是正在运行。

file
file

5年前 评论

根据《Laravel中文文档》中的配置的laravel-worker.ini
file
执行到sudo supervisorctl start laravel-worker:*这段命令后报错了
Horizon配置守护进程--Supervisor中遇到的一些问题(Aws\Sqs\SqsClient not found)
于是尝试手动执行配置文件中的artisan命令,再次报错...
Horizon配置守护进程--Supervisor中遇到的一些问题(Aws\Sqs\SqsClient not found)
不死心,就追踪这个类,结果发现根本就没有这个类,后来以为是laravel5.5的问题,追踪到5.8依然找不到指定的类文件...
Horizon配置守护进程--Supervisor中遇到的一些问题(Aws\Sqs\SqsClient not found)
后来把sqs去除执行了下发现可以正常使用了
Horizon配置守护进程--Supervisor中遇到的一些问题(Aws\Sqs\SqsClient not found)

想问博主知道``sqs```这个参数的实际意义嘛?

4年前 评论
easonshi 2年前

你好、CentOS 7.5怎么安装配置?

4年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!