我有一个运行1个小时的脚本.我有2个webhost,在其中一个,我可以实时看到输出,(它循环一百万次并回声)而在另一个webhost上,我必须等到脚本完成运行才能看到任何输出所有.
如何更改设置以实时显示输出?我想这是一个php.ini的事情.
添加代码:此代码将在第一个服务器中执行时输出,但不会在第二个服务器中输出.附加信息,如果我将值1015降低,则第一个服务器等待输出.所以我的第一台服务器似乎每隔1015个字符刷新一次,而第二台服务器则没有.
while ($a++ < 5) {
$b = 0;
while ($b++ < 1015) {
echo "H";
}
echo "<br><br>\n";
sleep(1);
}
Run Code Online (Sandbox Code Playgroud)
在我的第二台服务器上,输出缓冲关闭,我尝试打开implicit_flush无济于事.
这与输出缓冲有关.如果打开输出缓冲,则输出不会立即发送到客户端,而是等待缓冲一定量的数据.这通常会提高性能,但会导致像您这样的问题.
简单的解决方案不需要更改任何php.ini设置,只需将其放在脚本的开头:
<?php
while (@ob_end_flush());
?>
Run Code Online (Sandbox Code Playgroud)
这将立即刷新并禁用所有输出缓冲.
(来源:http://www.php.net/manual/en/function.ob-end-flush.php#example-460)
您可能还想阅读输出控制的PHP手册.此处php.ini列出了相关设置.
如果您想确保发送的内容(即在耗时的任务之前),请flush()在适当的时间致电.
编辑:
事实上,浏览器可能有自己的缓冲区,尤其是当未明确设置Content-Type时(浏览器需要嗅探文件的MIME类型).如果是这种情况,则无法控制浏览器的行为.
可能解决它的一种方法是显式设置Content-Type:
header("Content-Type: text/plain"); // if you don't need HTML
// OR
header("Content-Type: text/html");
Run Code Online (Sandbox Code Playgroud)
但这并不能保证有效.它适用于我的Firefox但不适用于Chrome.
无论如何,您的最终代码应如下所示:
header("Content-Type: text/html"); // Set Content-Type
while (@ob_end_flush()); // Flush and disable output buffers
while ($a++ < 5) {
$b = 0;
while ($b++ < 1015) {
echo "H";
//flush(); // In fact because there is no significant delay, you should not flush here.
}
echo "<br><br>\n";
flush(); // Flush output
sleep(1);
}
Run Code Online (Sandbox Code Playgroud)