Hello! 欢迎来到小浪资源网!

Laravel延迟队列任务执行失败:如何解决任务积压导致的超时问题?


Laravel延迟队列任务执行失败:如何解决任务积压导致的超时问题?

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));

相关阅读