队列执行超时报错

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,
        ],
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 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年前

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