php - PHP 脚本中的最大执行时间错误,这是绕过它的好方法吗?

标签 php max command-line-interface execution-time

我是数据库的唯一管理员。我想运行一个一次性脚本,基本上需要大约 3800 张扫描图像(它将增长到 1000 万)并使用 PHP exec() 函数为每个图像创建几个缩略图来执行外部程序 imagemagick 来创建这些缩略图。

我已经创建了脚本并启动了它并且一切正常!一切都在我的本地开发服务器上完成。该脚本大约需要 11 分钟来创建数千个缩略图。这是每隔一年运行一次的一次性操作,因此后果很小。

到目前为止一切顺利。这是我遇到问题的时候。

我在本地开发服务器上所做的一切都是出于测试目的在实时服务器上所做的。我有一个与 hostgator 共享的主机帐户。在共享主机上运行 11 分钟长的脚本时出现错误“超过 30 秒的最大执行时间...”。我做了我的研究,尝试了这篇文章 (Increase max execution time for php) 中找到的许多解决方案,只是意识到我无法改变共享主机上脚本的最长执行时间。

我卡住了。所以,我的问题是这里显而易见的解决方案是什么。

我正在考虑为每 200 张图像启动脚本,自动刷新页面并为接下来的 200 张图像再次运行脚本,依此类推,直到没有更多图像。通过这种方式,我可以确保我的共享主机上允许的 30 秒最长执行时间得到遵守。这看起来像是我脑海中的一个解决方案,但我不确定这是否是一个 NO NO,如果我要遇到更大的问题,太多的负面因素..

这是显而易见的解决方案吗?有人遇到同样的问题吗?你们有什么建议?

谢谢

最佳答案

假设您确实有理由批量重新创建缩略图,而不是像建议的那样在每次上传图像时都这样做,我会完全按照您的方式进行 - 使用一个可以自行刷新的脚本 - 除了我不会设置固定数量的图片。

相反,我会让脚本在每张图片后自行计时,并在达到(比如 25 秒)时停止:

$stop = time() + 25;
while (time() < $stop) {
    ...find image to process, process it.
    if (finished()) {
        die("OK");
    }
}
// Redirect to next batch of images
die(Header('Location: ....'));

但是,一定要与您的 ISP 联系,因为您的脚本可能会被视为滥用服务,或者可能被误认为是攻击。此外,询问一天中是否有运行此类维护的首选时间。

做同样事情的另一种更顽皮的方法是让脚本为非常少量的图像(可能是单个图像)运行每次有人点击主页。这具有使脚本的额外负载模拟服务器上的实际负载的效果,从而避免令人尴尬的峰值或神秘的非零基本负载。您确实需要找到一种永远不会从并行运行的脚本的不同实例中选择相同图像的方法(当我不得不这样做时,我在数据库中设置了一个标志)。

关于php - PHP 脚本中的最大执行时间错误,这是绕过它的好方法吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37148841/

相关文章:

来自多个表的 PHP 对象 - 性能

php - 如何使用 PHP 获取数据表

php - 从 cron 运行 php 脚本而不是选择 $_SERVER ['host' ] 从 CLI 运行的 wheras 工作

php - Eloquent/PHP 范围(从/到)

php - PHP解析/语法错误;以及如何解决它们

list - 如何从 CLIPS 的列表中找到最大元素?

if-statement - Tableau - 返回具有 MAX 值的维度

mysql - 内部联接以从行的总和中选择最大值

python - 如何根据第一个输入显示/隐藏输入选项?

amazon-web-services - 如何通过 aws cli 在 Amazon s3 中重命名 "PREFIX"?