队列执行超时报错

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 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 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年前

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