PHP flush 函数使用注意事项
ob_*系列函数, 是操作php本身的输出缓冲区.
所以, ob_flush是刷新php自身的缓冲区.
而flush, 严格来讲, 这个只有在php做为apache的module(handler或者filter)安装的时候, 才有实际作用.
它是刷新webserver(可以认为特指apache)的缓冲区.
在apache module的sapi下, flush会通过调用sapi_module的flush成员函数指针,
间接的调用apache的api: ap_rflush刷新apache的输出缓冲区, 当然手册中也说了, 有一些apache的其他模块,
可能会改变这个动作的结果..
有些apache的模块,比如mod_gzip,可能自己进行输出缓存,这将导致flush()函数产生的结果不会立即被发送到客户端浏览器。
甚至浏览器也会在显示之前,缓存接收到的内容。例如 netscape浏览器会在接受到换行或 html标记的开头之前缓存内容,并且在接受到 标记之前,不会显示出整个表格。
一些版本的 microsoft internet explorer
只有当接受到的256个字节以后才开始显示该页面,所以必须发送一些额外的空格来让这些浏览器显示页面内容。
所以, 正确使用俩者的顺序是. 先ob_flush, 然后flush,
当然, 在其他sapi下, 不调用flush也可以, 只不过为了保证你代码的可移植性, 建议配套使用.
<?php // set_time_limit(0); header('content-type: text/event-stream'); header('cache-control: no-cache'); // ob_end_flush(); // ini_set('output_buffering', 0); // ini_set('implicit_flush', 1); if (ob_get_level() == 0) ob_start(); echo str_repeat(' ' ,4096); $long = 60; while($long > 0) { $time = date('r'); echo "data: the server time is: {$time}\n\n"; ob_flush(); flush();//break; sleep(1); $long --; } // var source=new eventsource("http://localhost:18000/sse.php");source.onmessage=function(event){console.info(event.data)}; ?>
如果要在 nginx + fpm + php 上支持需要加一个响应头
header('x-accel-buffering: no');
this eliminates both proxy_buffering and (if you have nginx >= 1.5.6), fastcgi_buffering. the fastcgi bit is crucial if you're using php-fpm. the header is also far more convenient to do on an as-needed basis.
docs on x-accel-buffering ;
<?php // set_time_limit(0); header('content-type: text/event-stream'); header('cache-control: no-cache'); header('x-accel-buffering: no'); // ob_end_flush(); // ini_set('output_buffering', 0); // ini_set('implicit_flush', 1); // if (ob_get_level() == 0) ob_start(); // echo str_repeat(' ' ,4096); $long = 60; while($long > 0) { $time = date('r'); echo "data: the server time is: {$time}\n\n"; ob_flush(); flush();//break; sleep(1); $long --; } // var source=new eventsource("http://localhost:18000/sse.php");source.onmessage=function(event){console.info(event.data)}; ?>
上一篇: 修改Innodb的数据页大小以优化MySQL的方法
下一篇: 基于JVM性能监控命令介绍