队列执行超时报错

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,
        ],
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 3

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

4年前 评论

@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

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

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

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

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

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