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 队列,连接到 tcp://smtp.office365.com:587 超时