队列执行超时报错

laravel6.2
php7.3

有多个队列任务,有的执行时间稍长,有的执行时间很短,什么原因导致本来执行时间很短的任务也超时了呢?Illuminate\Queue\MaxAttemptsExceededException: App\Jobs\ArtisanQueueUpdate has been attempted too many times or run too long. The job may have previously timed out

'database' => [
            'driver' => 'database',
            'table' => 'jobs',
            'queue' => 'default',
            'retry_after' => 300,
        ],
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 3

也许不一定是超时,可能是尝试次数太多导致的失败,具体要看 fail jobs 表,或者安装 horizon 分析

2年前 评论

@MArtian 并没有设置重试,failed_jobs表错误信息

| 4112 | database   | default | {"displayName":"App\\Jobs\\ArtisanQueueUpdate","job":"Illuminate\\Queue\\CallQueuedHandler@call","maxTries":null,"delay":null,"timeout":null,"timeoutAt":null,"data":{省略}Illuminate\Queue\MaxAttemptsExceededException: App\Jobs\ArtisanQueueUpdate has been attempted too many times or run too long. The job may have previously timed out

比如这个任务本来是一两秒就该执行完的,不知道什么原因导致他执行失败了

2年前 评论
MArtian 2年前
西部荒野 (作者) (楼主) 2年前

还有一种可能性,就是两个队列共用了一个数据库中的表,也会导致这种情况产生

2年前 评论
西部荒野 (楼主) 2年前
我爱大可乐 (作者) 2年前
西部荒野 (楼主) 2年前
我爱大可乐 (作者) 2年前
西部荒野 (楼主) 2年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!