Laravel队列进程超时错误

Wil*_*ney 37 php queue timeout symfony laravel

我在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.
Run Code Online (Sandbox Code Playgroud)

我知道我可以运行queue:listen一个任意高的超时值,但是这不是理想的,因为我希望它的活动时间,一些过程实际上 unreseponsive.我尝试set_time_limit(60)在作业调用的函数内定期调用,但这并没有解决我的问题.

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

任何帮助将非常感激.

Dav*_*ian 62

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

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

希望这可以帮助.

  • 其他用户的旁注:将超时设置为0可能会很危险,可能导致"不可见"无限循环.也许使用像120这样"合理"的东西. (18认同)
  • @Rizh然后我会说你的设计有问题。您永远不应该依赖需要运行很长时间才能执行某些操作的进程。将其分解为更小的组件。 (2认同)

Anm*_*rya 11

在投入了大量时间后,我得到了解决方案

在 Job 类中添加以下行,即使您将作业放在 crontab 条目中,您的作业也不会超时运行

public $timeout = 0;
Run Code Online (Sandbox Code Playgroud)