1. 程式人生 > >Nginx+phpfastcgi下flush 一下子全部輸出問題

Nginx+phpfastcgi下flush 一下子全部輸出問題

die() lee 如果 cgi header cnblogs encoding fpm 運行

最近由於業務需要,需要使用php的flush輸出緩存刷新,處理瀏覽器超時問題.

最初的測試代碼如下:

ob_start();//打開緩沖區
for ($i=10; $i>0; $i--)
{
echo $i.‘<br />‘;
ob_flush();
flush();
sleep(1);
}
ob_end_flush();//輸出並關閉緩沖
die();
本以為這樣就能1秒鐘輸出一個數字,但是在nginx+php的環境下,實際產生的結果與預期是不一樣的,結果是10秒後數據一次性都輸出出來了。

以前在apache裏運行正常,每隔1秒動態刷新瀏覽器輸出緩存內容,那是因為apache裏沒有開啟gzip。糾結了半天,上網查了許久的問題,最後解決的方法如下:

header("Content-Encoding: none\r\n");
ob_start();//打開緩沖區
for ($i=10; $i>0; $i--)
{
echo str_repeat(" ",1024*64);
echo $i.‘<br />‘;
ob_flush();
flush();
sleep(1);
}
ob_end_flush();//輸出並關閉緩沖
die;

  


解釋下為什麽要這麽寫這段代碼:

首先:header("Content-Encoding: none\r\n");解決nginx在配置文件中開啟了gzip的問題,如果nginx的gzip的配置項是on,而不加這行代碼,結果還是一樣等程序執行完畢後一次性的把數據輸出出來;其實也可以不用加這行代碼,直接在nginx配置文件中關閉gzip,但是不能因為一個小需求而改nginx的配置吧。

其次:echo str_repeat(" ",1024*64)這行代碼也是重點,一開始我也沒有加這行代碼,最後的實現的效果還是一次性的把數據輸出出來,造成的原因是nginx中的 fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;

這兩個配置表示Nginx會緩沖PHP-FPM輸出的信息,當達到64k時才會將緩沖區的數據發送給客戶端,由於我們只輸出了一個數字,遠遠不到64k這個上限,所以在程序輸出之前加上echo str_repeat(" ",1024*64);1024*64值根據個人的nginx配置進行修改。

最後一點:ob_flush()和flush()要結合使用,而且ob_flush要在flush之前,flush才是真正的輸出。

Nginx+phpfastcgi下flush 一下子全部輸出問題