PHP   发布时间:2022-04-04  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了php-Laravel排队的作业比超时时间长很多大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

我有一个Laravel排队的工作,它从网页中提取链接.通过Laravel Forge配置的队列侦听器的超时为240秒(4分钟).但是,作业最多需要45分钟才能运行.

我的队列设置是:

'redis' => [
    'driver' => 'redis',
    'connection' => 'default',
    'queue' => 'default',
    'retry_after' => 350,
],

并且有多个作业流程在运行-多达35个流程.可以想象,这正在消耗大量服务器内存.这些过程似乎一直徘徊.如上所示,这些过程的命令是:

PHP7.1 artisan queue:work redis --once --queue=linkqueue --delay=0 --memory=128 --sleep=10 --tries=1 --env=local

如果超时为240秒,作业如何运行45分钟?为什么会有这么多流程-不应该只有一个流程吗?

还有,为什么要提取链接的脚本要花45分钟才能运行?

该脚本确实可以正常工作,也就是说,在大多数情况下,它可以按预期运行,并且需要很长时间.据我所知,没有报告/记录错误.

工作中的代码是:

$dom = new DOMDocument;
$dom->loadHTML($html);
$links = $dom->getElementsByTagName('a');

foreach ($links as $a) {
    $link = $a->getAttribute('href');

    $newurl = new URL;
    $newurl->url = $link;
    $newurl->save();
}

更新:另一个简单的工作就可以在不到一秒钟的时间内运行良好.特别是上面的链接作业​​需要10分钟的时间.可能是RAM问题吗?我还能做些什么来诊断问题?作为控制台作业的一部分运行时,提取链接功能本身将在1或2秒内运行.它只是在队列中吓坏了.

解决方法:

因为您有’retry_after’=> 350,在您的队列连接上.这意味着如果Laravel在350秒后没有收到作业的消息-则认为作业已失败并再次重试.这导致您遇到的情况是一项工作的多个过程.

如果您愿意让您的作业最多运行45分钟-那么您应该将retry_after设置为更大的数字.说3600,即1小时.

这样,只有在运行时间超过1小时后,作业才能开始.

大佬总结

以上是大佬教程为你收集整理的php-Laravel排队的作业比超时时间长很多全部内容,希望文章能够帮你解决php-Laravel排队的作业比超时时间长很多所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: