laravel queue java_laravel queue的使用--一些命令

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值