Apache mod_fcgid php缓冲区问题
2017-03-03 12:59
316 查看
Apache mod_fcgid php缓冲区问题
测试环境PHP version 5.3.29/5.6.29/7.1.0
Apache/2.4.25 (Win32) mod_fcgid/2.3.9
问题描述
Apache使用mod_fcgid 配置php出现的问题:在php.ini中配置output_buffering = Off或者output_buffering = 4096 均不能使用ob_flush()和flush()刷出缓冲区内容在php.ini中设置缓冲区 output_buffering = 4096 ;开启php缓冲区 output_buffering = Off ;关闭php缓冲区
问题分析
在不同版本的php.ini中均关闭缓冲区,测试发现全都不生效,排除php.ini配置文件的问题;由于三个版本的php是由mod_fcgid配置的,初步定位是mod_fcgid配置问题。
解决办法
查找官方文档发现,FcgidOutputBufferSize配置信息如下:mod_fcgid documentDescription: CGI output buffer size Syntax: FcgidOutputBufferSize bytes Default: FcgidOutputBufferSize 65536 Context: server config, virtual host Status: External Module: mod_fcgid
Apache mod_fcgid模式默认为开启buffer,所以在Apache配置文件httpd.conf 中设置
FcgidOutputBufferSize 0
重新测试代码,发现ob_flush()和flush()函数可用,即php.ini中配置缓冲区信息生效。
测试代码
测试要求在浏览器中间隔一秒出现一个数字:一次php代码文件请求涉及两个缓冲区:
php缓冲区:php编译生成的静态内容首先被php缓冲区收集,之后再对外输出;
browser缓冲区:从服务器过来的内容到达浏览器里边的时候,首先被浏览器缓冲区收集,收集满之后再逐渐展示到页面上;
<?php //提前开启缓冲区,在php.ini中配置output_buffering = 4096; //提前开启缓冲区,或者在运行时设置ob_start(); for($i=0;$i<5;$i++){ echo $i,'<br/>'; ob_flush(); //刷出php缓冲区内容 flush(); //刷出浏览器缓冲区内容 sleep(1); }
相关文章推荐
- Windows下FastCGI安装PHP(Apache mod_fcgid)
- Windows下PHP使用Apache的mod_fcgid模块安装及配置
- 悬而未决:APACHE上开启mod_fcgid.so后打开PHP一片空白
- 在RHEL 5.3(Tikanga)上配置Apache + FastCGI(mod_fcgid) + PHP
- PHP 7 Apache 2.4 fastcgi mod_fcgid配置方法
- php bug? php的exit函数和apache的mod_include混用导致的问题
- apache+php 字符编码问题解决
- 解决Fedora Core 3及后续版本中Apache无法加载libphp4.so模块的问题
- 给apache2.2加上mod_encoding模块後 php5.2.0 处理url出现bug
- 使用php 的缓冲区功能和apache的url重写功能实现静态html生成实例
- Linux apache2.2 php 5.2 mysql 5.0 问题总结
- windows下配置PHP5.2.5+Apache 2.2.9+MySQL 6.0.5问题解决
- CentOS 4.4 编译安装 apache 2.2.4(mod_ssl)+php 5.2.1 wi
- gd+apache+mysql+php+eacceleratot+zend 问题
- Django在使用mod_python+apache中配置VirtualHost的问题总结
- mysql+apache+php======myphpamdin的问题:
- apache install php resin mod_gzip mod_expire webalizer cronolog
- apache+php4+mysql5 无法连接问题的解决。
- 最新版 linux Fedora 下apache2.2 +mysql5.1.5 +php5.12 +GD +mod_limitipconn... 安装指南
- PHP5+Apache连接Oracle问题