Laravel队列进程超时错误

问题描述 投票:31回答:2

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

[Symfony\Component\Process\Exception\ProcessTimedOutException]                                                                                                                                                                              
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),但这并没有解决我的问题。

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

任何帮助将非常感激。

php symfony laravel timeout queue
2个回答
54
投票

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

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

希望这可以帮助。


1
投票

这是Laravel v5.3中已知的bug

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

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

© www.soinside.com 2019 - 2024. All rights reserved.