|  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Bug #68911 ob_flush() works only when producing notice
Submitted: 2015-01-25 17:39 UTC Modified: 2015-01-29 14:06 UTC
From: david at davidsteinsland dot net Assigned:
Status: Not a bug Package: Output Control
PHP Version: 5.5.21 OS: OSX Yosemite
Private report: No CVE-ID: None
 [2015-01-25 17:39 UTC] david at davidsteinsland dot net
This is a weird issue, but I'm trying to setup a basic Server Sent Event example.

The goal is to flush the messages to the browser on each event.

When viewing the script in my browser, or testing it using the JavaScript API, the messages seem to be flushed correctly. However, I notice that the script produces an error:
Notice (8): ob_flush() [ref.outcontrol]: failed to flush buffer. No buffer to flush

If I try to "fix" that notice by putting the shutup operator in front of ob_flush(), or putting it inside an "if (ob_get_level())" statement, the messages are now longer flushed properly. The browser and JavaScript API will wait perhaps 10 seconds before producing output.

But if I let the notice be displayed, each message is flushed correctly.

What is the reason behind this?

Test script:

for ($i = 0, $j = ob_get_level(); $i < $j; $i++) {

$stop = false;
for ($i = 0; $i < 1000; ++$i) {
	$duration = microtime(true) - env('REQUEST_TIME_FLOAT');

	echo "event: userconnect\n";
	echo 'data: {"username": "bobby", "time": "02:33:48"}';
	echo "\n\n";

	echo "data: Here's a system message of some kind that will get used\n";
	echo "data: to accomplish some task.";
	echo "\n\n";

	echo "event: usermessage\n";
	echo 'data: {"username": "bobby", "time": "02:34:11", "text": "Hi everyone."}';
	echo "\n\n";

	// Notice here


Expected result:
Each message be flushed when written.

Actual result:
Chunk of output gets flushed at the same time, after a waiting period.
If the notice gets displayed, it works.


Add a Patch

Pull Requests

Add a Pull Request


AllCommentsChangesGit/SVN commitsRelated reports
 [2015-01-29 14:06 UTC]
-Status: Open +Status: Not a bug
 [2015-01-29 14:06 UTC]
You stop any output buffers with the first loop.
So ob_flush() in the second produces the error.
Use flush() to flush the SAPI's output stream instead.
PHP Copyright © 2001-2024 The PHP Group
All rights reserved.
Last updated: Wed May 22 00:01:33 2024 UTC