PHP-php里set_time_limit超时失效

发布于 2017-06-27 16:27:32 字数 335 浏览 1564 评论 1

为什么set_time_limit(10)不管用

<?php
echo ini_get('safe_mode') ? 'safe_mode' : 'no safe_mode', PHP_EOL;
set_time_limit(10);
echo date('Y-m-d H:i:s', time()),PHP_EOL;
while($i++<20) sleep(1);
echo date('Y-m-d H:i:s', time()),PHP_EOL;

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

浮生未歇 2017-08-15 18:50:11

set_time_limit() 函数和配置指令 max_execution_time 只影响脚本本身执行的时间。任何发生在诸如使用 system() 的系统调用网络请求,流操作,数据库操作等的脚本执行的最大时间不包括其中,当该脚本已运行。在测量时间是实值的 Windows 中,情况就不是如此了。

sleep 进行系统调用时,所费时间不计入。

下面这种计入

echo ini_get('safe_mode') ? 'safe_mode' : 'no safe_mode', PHP_EOL;
set_time_limit(30);
echo date('Y-m-d H:i:s', time()),PHP_EOL;
#while($i++<20) sleep(1);
while(true);
echo date('Y-m-d H:i:s', time()),PHP_EOL;

[root@uplook-test1 php_test]# php setTimeLimit.php
no safe_mode
2014-09-16 19:41:33

Fatal error: Maximum execution time of 30 seconds exceeded in /home/qzw881130/php_test/setTimeLimit.php on line 8

网络请求所占用时间也不计入脚本执行时间

echo ini_get('safe_mode') ? 'safe_mode' : 'no safe_mode', PHP_EOL;
set_time_limit(30);
echo date('Y-m-d H:i:s', time()),PHP_EOL;
#下面网络请求,sleep.php 会 sleep 50 秒,这个时间也不计入脚本执行时间
$url = "http://localhost/sleep.php";
file_get_contents($url);
echo date('Y-m-d H:i:s', time()),PHP_EOL;
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文