Laravel队列进程超时错误

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Laravel队列进程超时错误相关的知识,希望对你有一定的参考价值。

我在Laravel上使用php artisan queue:listen来运行排队的工作。其中一个工作相当复杂,需要很长时间,因此我收到以下错误:

[SymfonyComponentProcessExceptionProcessTimedOutException]                                                                                                                                                                              
The process ""/usr/local/Cellar/php55/5.5.14/bin/php" artisan queue:work  
--queue="QUEUE_URL" --delay=0 --memory=128 --sleep=3 --tries=0" 
exceeded the timeout of 60 seconds.

我知道我可以运行具有任意高超时值的queue:listen,但这并不理想,因为我希望它在某些进程实际上没有响应的情况下超时。我尝试在作业调用的函数中定期调用set_time_limit(60),但这并没有解决我的问题。

我发现在线提到SymfonyComponentProcessProcess->setTimeout(null)的线程,但我不知道如何访问该进程对象,或者如果这甚至可以解决问题。

任何帮助将非常感激。

答案

添加--timeout=0为我的设置工作。

更新:整个命令因此将是php artisan queue:listen --timeout=0

希望这可以帮助。

另一答案

这是Laravel v5.3中已知的bug

您应升级到v5.5以解决此问题。

另一种方法是黑客攻击源代码,如here所述

以上是关于Laravel队列进程超时错误的主要内容,如果未能解决你的问题,请参考以下文章

Laravel - 从路由调用工匠队列命令 - 邮递员超时

Laravel 队列,连接到 tcp://smtp.office365.com:587 超时

Supervisor管理Laravel队列进程报错

在 Laravel/Lumen 中动态创建的工作守护进程队列

Redis队列和swoole的多进程哪个好

Laravel 5.1:Elastic Beanstalk 工作层设置队列