Nginx+phpfastcgi下flush 一下子全部輸出問題
最近由於業務需要,需要使用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 一下子全部輸出問題