PHP loop; how to print each result and delay it for a second before echoing another result?

13,755

Servers usually buffer the output of a server side script until there's enough in it to output try something like this. Combination of setting output buffering off and manually flushing the buffer. Note the implcit flush line and the flush and ob_flush lines.

<?php 
@ini_set("output_buffering", "Off");
@ini_set('implicit_flush', 1);
@ini_set('zlib.output_compression', 0);
@ini_set('max_execution_time',1200);


header( 'Content-type: text/html; charset=utf-8' );


echo "Testing time out in seconds\n";
for ($i = 0; $i < 1150; $i++) {
    echo $i." -- ";

    if(sleep(1)!=0)
    {
        echo "sleep failed script terminating"; 
        break;
    }
    flush();
    ob_flush();
}

?>
Share:
13,755

Related videos on Youtube

Dwi Murdianto
Author by

Dwi Murdianto

Updated on August 03, 2022

Comments

  • Dwi Murdianto
    Dwi Murdianto over 1 year

    this is my first question here on stackoverflow, I just curious.. is it possible to delay loop in PHP ? I'm trying to print each result to browser and pause the script using sleep() before it process another loop, but it's not working, here's the script that I use:

    <?php
    $n = 1;
    
    while ($n < 10) {
        echo $n."<br />";
        $n++;
        sleep(1);
    }
    ?>
    

    PS: I'm using Firefox and Apache2 on Linux Mint.

  • Rich
    Rich about 11 years
    It can be done server side if need be by switching off output buffering and flushing the buffer manually. Whether it's the right solution is another thing.
  • Rich
    Rich about 11 years
    Nice that something I struggled with a while ago is helping out ;)
  • Rakhi
    Rakhi almost 9 years
    if we don't write the code above 4 lines with ini_set its still working same? are they set by default on localhost?
  • Rich
    Rich almost 9 years
    @vishal the ini_set is used to force the settings to override whatever the values have been set to at server level. If you don't have the top 4 lines then the likelyhood is that the server will buffer the output and also my test script will timeout as it probably exceeds the maximum execution time allowed by the server. As the for zlib compression line, not sure if it's required or not but by virtue that output buffering is turned off, there's no buffer to compress, so logically you dont want output compression.
  • Rakhi
    Rakhi almost 9 years
    ok also this is good way to add sleep for long process to avoid execution time error and also same time show the process log to user but if we add sleep on each iteration that exceeds the time so much means at Evey iteration it sleeps.Is this good way for lengthy process loop?
  • Rich
    Rich almost 9 years
    @vishal, using sleep function will only extend the script timeout length on windows, on linux it has no effect . stackoverflow.com/questions/740954/…
  • Puneeth
    Puneeth about 8 years
    @Rich, Exactly it takes pretty much to time to load and displays 3 iterations at a time for the first time in Ubuntu Linux.