laravel 延迟队列分发失效
问题描述:
在指定时间内执行更新订单状态的任务时,延迟队列不执行或超时。
具体内容:
- 业务场景:在指定时间内更新订单状态
- 错误日志:appjobssettlementorder has been attempted too many times or run too long. the job may have previously timed out.
-
相关配置:
- queue_driver=redis
- queue_connection=redis
- redis_host=127.0.0.1
- redis_port=6379
- 任务代码:$jobres = settlementorder::dispatch([‘id’ => 1])->delay(now()->addseconds(60));
问题原因:
未指定唯一队列,导致大量任务积压,造成延迟队列不执行或超时。
解决方案:
在任务分发时指定一个唯一队列,确保任务不会相互堵塞。
示例代码:
$jobRes = SettlementOrder::dispatch(['id' => 1])->onQueue('unique_queue_name')->delay(now()->addSeconds(60));
登录后复制
以上就是Laravel延迟队列任务执行失败:如何解决任务积压导致的超时问题?的详细内容,更多请关注php中文网其它相关文章!