laravel4.2中队列的使用

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:*

```

推荐阅读更多精彩内容