PHP脚本在超过60秒时执行两次

PHP脚本在超过60秒时执行两次,php,apache,Php,Apache,好吧,过去的3个小时里,我一直在绞尽脑汁,疯狂地在谷歌上搜索,没有找到解决问题的办法。所以,我写了一个示例脚本,它复制了这个脚本,因为我的原始脚本大约有800行 <?php set_time_limit(0); ini_set('max_input_time', '-1'); ini_set('max_execution_time', '0'); error_log("executing script... "); $time = time();

好吧,过去的3个小时里,我一直在绞尽脑汁,疯狂地在谷歌上搜索,没有找到解决问题的办法。所以,我写了一个示例脚本,它复制了这个脚本,因为我的原始脚本大约有800行

<?php
    set_time_limit(0);
    ini_set('max_input_time', '-1');
    ini_set('max_execution_time', '0');

    error_log("executing script... ");
    $time = time();
    for ($t = 0; $t <= 15; $t++) {
        error_log("Logging: $t (".(time()-$time)." seconds)");
        sleep(5);
    }
    error_log("execution done (".(time()-$time)." seconds)");
?>
以下是phpinfo中的一些相关设置

=== apache2handler ===
Max Requests: Per Child: 1000 - Keep Alive: on - Max Per Connection: 200
Timeouts: Connection: 300 - Keep-Alive: 2 

=== PHP Version 5.4.5 Core Settings ===
max_execution_time     Local: 0     Master: 30
max_input_time         Local: -1    Master: -1
我已经尝试了我能想到的一切。这似乎是Apache或PHP的服务器设置,因为当我在本地主机上运行相同的脚本时,它会像没有双重负载时一样成功执行。在它被问到之前,是的,每次我更改INI或apache配置时,我都会重新启动apache

此外,下面是上面示例的访问日志条目

*.*.*.* - - [06/Nov/2012:16:43:56 -0700] "GET /test.php HTTP/1.1" 200 20 "-" "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:16.0) Gecko/20100101 Firefox/16.0" *.*.*.* *********.com 80 55050278 1012 321 *.*.*.*
*.*.*.* - - [06/Nov/2012:16:44:56 -0700] "GET /test.php HTTP/1.1" 200 20 "-" "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:16.0) Gecko/20100101 Firefox/16.0" *.*.*.* *********.com 80 60054985 1012 321 *.*.*.*
当执行时间达到60秒时,肯定会有这样的事情发生,因为当我将执行时间改为55秒时,它会正常运行一次

[Tue Nov 06 16:46:00 2012] executing script...
[Tue Nov 06 16:46:00 2012] Logging: 0 (0 seconds)
[Tue Nov 06 16:46:05 2012] Logging: 1 (5 seconds)
[Tue Nov 06 16:46:10 2012] Logging: 2 (10 seconds)
[Tue Nov 06 16:46:15 2012] Logging: 3 (15 seconds)
[Tue Nov 06 16:46:20 2012] Logging: 4 (20 seconds)
[Tue Nov 06 16:46:25 2012] Logging: 5 (25 seconds)
[Tue Nov 06 16:46:30 2012] Logging: 6 (30 seconds)
[Tue Nov 06 16:46:35 2012] Logging: 7 (35 seconds)
[Tue Nov 06 16:46:40 2012] Logging: 8 (40 seconds)
[Tue Nov 06 16:46:45 2012] Logging: 9 (45 seconds)
[Tue Nov 06 16:46:50 2012] Logging: 10 (50 seconds)
[Tue Nov 06 16:46:55 2012] execution done (55 seconds)

任何帮助都将不胜感激

为了排除这种可能性,您是否尝试过在其他浏览器中测试此功能?我之所以提到它,是因为我最近偶然发现了这一点:


可能是由于缺少favicon之类的原因导致脚本被调用两次。看见如果将非www重定向到www,也可能发生这种情况,反之亦然。请参见

作为解决方法,也许您可以将执行分为两页;完成第一个后,只需加载第二个。这也可以解决某些资源限制,例如PHP配置中的RAM预算较低。

没有favicon,否则我会在访问日志中看到它失败。将phpinfo()放在顶部的3个设置之后,看看它们是否生效。您应该添加一个favico。我没有,我的页面被加载了两次。只要我添加了一个,就可以了@sheac你是否根据另一篇链接文章重定向到/从www?有趣。。。在chrome中60秒后不会重复调用,但是chrome在执行60秒后不会收到页面响应。这仍然不能解释为什么当执行时间超过60秒时,同一个脚本会在本地主机apache服务器上工作,除非它与浏览器发出外部请求有关,而不是内部请求。嗯,我不认为这和它涉及的扩展是一样的,但是非常相似,可能值得一看。我也看到了这种情况——我仍然对解决方案抱有希望。
[Tue Nov 06 16:46:00 2012] executing script...
[Tue Nov 06 16:46:00 2012] Logging: 0 (0 seconds)
[Tue Nov 06 16:46:05 2012] Logging: 1 (5 seconds)
[Tue Nov 06 16:46:10 2012] Logging: 2 (10 seconds)
[Tue Nov 06 16:46:15 2012] Logging: 3 (15 seconds)
[Tue Nov 06 16:46:20 2012] Logging: 4 (20 seconds)
[Tue Nov 06 16:46:25 2012] Logging: 5 (25 seconds)
[Tue Nov 06 16:46:30 2012] Logging: 6 (30 seconds)
[Tue Nov 06 16:46:35 2012] Logging: 7 (35 seconds)
[Tue Nov 06 16:46:40 2012] Logging: 8 (40 seconds)
[Tue Nov 06 16:46:45 2012] Logging: 9 (45 seconds)
[Tue Nov 06 16:46:50 2012] Logging: 10 (50 seconds)
[Tue Nov 06 16:46:55 2012] execution done (55 seconds)