【介绍】
Supervisor 是一个 Python 写的进程管理工具,有时一个进程需要在后台运行,并且意外挂掉后能够自动重启,就需要这么一个管理进程的工具。
在 Laravel 开发中,也经常使用到队列监听,可以配合 Supervisor 来管理 Laravel 队列进程。
官网:http://supervisord.org
参考:https://learnku.com/laravel/t/3592/using-supervisor-to-manage-laravel-queue-processes
【安装】
使用 pip 工具进行安装:
sudo pip install supervisor
Ubuntu 系统使用 apt-get
sudo apt-get install supervisor
【配置】
运行以下命令生成默认配置文件:
echo_supervisord_conf > /etc/supervisord.conf
编辑这个文件,把最后的 include 块的注释打开,并修改如下:
[include] files = /etc/supervisor/*.conf
新增的 Supervisor 配置文件放在 /etc/supervisor 目录下,并且以 conf 结尾。
使用新的配置文件来启动 Supervisor:
supervisord -c /etc/supervisord.conf
如果提示已经有进程在运行,那么先 kill 掉它。
创建目录: /etc/supervisor
mkdir /etc/supervisor
创建日志目录:
mkdir /var/log/supervisor && chmod -R 777 /var/log/supervisor
使用 Supervisor 管理 Laravel 队列进程:
php artisan queue:work 命令用于监听 Laravel 队列,通过 nohup 方式让它在后台运行。但是进程如果意外中断是不会自动重启的,所以使用 Supervisor 来监控进程是个很好的方式。
首先在 /etc/supervisor 目录下新增配置文件:supervisor.conf
[program:laravel-worker] process_name=%(program_name)s_%(process_num)02d command=php /usr/local/nginx/html/virtualnic.com/portal/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 把用户和组设置正确,另外把日志文件权限设置为 777.
chown vagrant:vagrant file_name
再次经过上述步骤,成功开启进程管理:
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 的队列管理才能生效。