queue:listen和queue:work 区别
queue:work 默认只执行一次队列请求, 当请求执行完成后就终止;
queue:listen 监听队列请求, 只要运行着, 就能一直接受请求, 除非手动终止;
queue:work --daemon 同 listen 一样, 只要运行着, 就能一直接受请求, 不一样的地方是在这个运行模式下, 当新的请求到来的时候, 不重新加载整个框架, 而是直接 fire 动作. 终端上不会显示 Processed: SaveAvatorjob
能看出来, queue:work --daemon 是最高级的, 一般推荐使用这个来处理队列监听.
注意: 使用 queue:work --daemon , 当更新代码的时候, 需要停止, 然后重新启动, 这样才能把修改的代码应用上.
php artisan queue:listen --queue=saveAvatorQueue --tries=3 监听某个队列
一些命令及解释
php artisan queue:listen --queue CreateXmlQueue --memory=4096 --timeout=6000
可以指定监听器使用哪个队列连接
php artisan queue:listen connection
可以设置每个任务允许运行的最大时间(以秒为单位)
php artisan queue:listen --timeout=60
可以指定轮询新任务之前的等待时间(以秒为单位):
php artisan queue:listen --sleep=5
可以在queue:listen命令上使用--tries开关来指定任务最大可尝试执行次数:
php artisan queue:listen connection-name --tries=3
Supervisor配置
Supervisor为Linux操作系统提供的进程监视器,将会在失败时自动重启queue:listen
或queue:work
命令,要在Ubuntu上安装Supervisor,使用如下命令:
sudo apt-get install supervisor
Supervisor配置文件通常存放在/etc/supervisor/conf.d目录,在该目录中,可以创建多个配置文件指示Supervisor如何监视进程,例如,让我们创建一个开启并监视queue:work进程的laravel-worker.conf文件:
[program:laravel-worker]
process_name=%(program_name)s_%(process_num)02d
command=php /home/forge/app.com/artisan queue:work sqs --sleep=3 --tries=3 --daemon
autostart=true
autorestart=true
user=forge
numprocs=8
redirect_stderr=true
stdout_logfile=/home/forge/app.com/worker.log
在本例中,numprocs指令让Supervisor运行8个queue:work进程并监视它们,如果失败的话自动重启。配置文件创建好了之后,可以使用如下命令更新Supervisor配置并开启进程:
sudo supervisord -c /etc/supervisord.conf
sudo supervisorctl -c /etc/supervisor/supervisord.conf
sudo supervisorctl reread
sudo supervisorctl update
sudo supervisorctl start laravel-worker:*