PHP sleep()内部循环不更新DB

时间:2009-11-24 00:32:06

标签: php mysql loops sleep flush

我有一个每分钟由cronjob触发的php文件。

当php文件被触发时,它会更新数据库,睡眠等

它的编程方式如下:

$start = microtime(true);
set_time_limit(10);

for($i=0;$i<5;$i++)
{
    updateDB();
    time_sleep_until($start + $i + 1);
}

如果运行这段代码,我看不到数据库中发生任何变化。我注意到的另一件事是当我回应一些东西时,我会在循环结束时打印出来。

[edit]我尝试过使用flush和ob_flush,但它仍然没有打印行[/ edit]

我该怎么做才能避免这些错误。数据库需要更新。

我想知道的另一件事是记录这类事情的最佳方法。我可以将结果记录到日志文件中。

2 个答案:

答案 0 :(得分:4)

循环本身看起来很好。如果它没有更新您的数据库,则错误必须在 updateDB()函数中。

至于回声的事情。脚本的输出通常是缓冲的。要强制PHP立即打印它,您可以在需要刷新输出时调用flush(),或者只需在脚本顶部调用ob_implicit_flush(),它就会在您每次自动刷新时自动刷新打印东西。

此外,如果您通过浏览器调用脚本,浏览器本身可能会在显示响应之前进一步缓冲响应。

至于日志记录,最简单的方法是在某处选择一个文件,然后使用file_put_contents()打印您想要记录的内容。请注意第三个参数的 FILE_APPEND 标志。

答案 1 :(得分:0)

看起来你是从命令行运行的,在这种情况下你可能想写入stderr以便没有缓冲。 $ stderr = fopen('php:// stderr','w');

在记录的情况下,只需打开一个文件,写入并关闭它。 (fopen,fwrite,fclose);