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:work --queue=saveAvatorQueue
只把已经推送(push)的队列里执行一次 名称为saveAvatorQueue队列。
执行成功终端会输出Processed: SaveAvatorjob
php artisan queue:work --queue=saveAvatorQueue --daemon
后台一直监听 名称为saveAvatorQueue队列的任务,会一直监听,代码改变后需要重新执行该命令。
执行成功终端不会输出任何东西
php artisan queue:listen --queue=saveAvatorQueue
一直监听名称为saveAvatorQueue队列的任务
执行成功终端会输出Processed: SaveAvatorjob
php artisan queue:listen
一直监听所有push到队列的任务
自我发现:
1、当给队列命名后 不指定 --queue=saveAvatorQueue ,就不会被监听,切记
2、如果在终端里执行 php artisan queue:listen,若报错后会一直执行报错,需要再加上 --tries=3(尝试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操作系统提供的进程监视器,将会在[失败](http://laravelacademy.org/tags/%e5%a4%b1%e8%b4%a5)时自动重启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:*
```