PHP的echo为什么这么慢

  作为一个行走江湖多年的老中医,今天受命去解决一例前端页面展现缓慢的问题。问题页的情况如下:

  apache + php

  使用smarty模板输出内容

  页面最终输出内容较大,80k+

  页面执行时间在500ms以上

  祭出法宝xhprof对问题页面做了细致检查,发现页面的瓶颈竟然是模板(编译后的)中的一个echo语句,这个echo语句输出的字符串比较大,大概是50k+字节,花费时间为400多毫秒,占整个页面执行时间的80%。这样的echo输出在站点首页中其实是很常见的事情,没有数据库操作,按道理执行时间不应该这么长。

  于是猛力使用搜索技能,最终在php手册的echo部分找到了一些蛛丝马迹,早在2003年就有前辈认为通过echo输出大字符串到客户端会引起服务器的性能问题,据我测试,在这个场景下使用print其实也是一样的慢。建议的解决办法是把字符串切割成更小的字符串输出,展现速度会有提升,输出函数如下:

  <?php

  function echobig($string, $bufferSize = 8192) {

  $splitString = str_split($string, $bufferSize);

  foreach($splitString as $chunk)

  echo $chunk;

  }

  ?>

  但是上面的处方不太对症,整个echobig的输出时间仍然在400毫秒左右,没有太大改善。

  考虑到是输出大量内容到客户端比较慢,于是检查了apache的配置,原来还没打开deflate进行压缩,遂启用之。再次使用xhprof进行检查,这条echo的输出时间降低到5ms左右。

  400ms到5ms,一个配置问题会产生80倍的差距,还真是省老钱了。这个故事告诉我们,压缩输出真的很重要。

UPDATE:加速你的echo http://www.php100.com/html/webkaifa/PHP/PHPyingyong/2011/1127/9361.html

时间: 2024-09-14 17:45:36

PHP的echo为什么这么慢的相关文章

Linux中echo命令实例

echo是一种最常用的与广泛使用的内置于Linux的bash和C shell的命令,通常用在脚本语言和批处理文件中来在标准输出或者文件中显示一行文本或者字符串. echo命令的语法是: echo [选项][字符串] 1. 输入一行文本并显示在标准输出上 $ echo Tecmintis a community of LinuxNerds 会输出下面的文本: Tecmintis a community of LinuxNerds 2. 输出一个声明的变量值 比如,声明变量x并给它赋值为10. $

linux 之 echo命令用法

# echo $PATH                /**显示系统总一些变量,必须加上$/    /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/arm/4.3.2/bin      /*显示的环境变量*/ # echo $HOME # echo $MAIL 其他的很多函数或者命令怎么只用  可以用man  来查看. 如果想把一个字符串在终端上打印出来,可以用如下命令: #

linux echo命令小记

今天在debian系统编辑文件,用到了linux echo命令,这里记录一下:  echo -e  "deb http://ftp.cn.debian.org/debian squeeze main\ndeb http://security.debian.org/ squeeze/updates main"  > /etc/apt/sourist 追加文件内容结尾不覆盖: # echo -e "this is a test\!" >>/test.l

Linux初学命令图文解说:echo

功能:显示文字. 常用参数:-n-e 提示:echo [ 参数 ] 字符串 例子

一个echo引起的进程崩溃

最近在编写后台程序时遇到一个问题.发现后台程序总是莫名其妙的die掉.经排查,发现罪魁祸首是一个echo.案情重现: 1.ssh登陆服务器 2.新建一个php文件test.php,代码如下: <?php sleep(50); echo "aaa\n"; file_put_contents("/tmp/test.txt",time()); ?> 3.用以下命令执行test.php程序 $ php test.php & 查看 /tmp/test.tx

做一个职业的酋长-访IT部落Echo

ITbulo.com  ALexa世界排名2万4000名 日访问IP4-5W 日PV20-22W站长echo,80年代生人.01年开始做个人主页,02年开始从事互联网方面的工作,一直到今天.目前正专职运营IT部落网站. 阻击者:晚上好,好久没聊了呵呵,你还记得你的第一个个人主页做的是什么内容么?第一个网站又是在什么样子的情况下诞生的?Echo:第一个个人主页"潇潇雨吧",断断续续做了近5年,最开始是以文学方面为主的,后来经过3次大的改版,最后形成了一个以网页相关教程.资源为主的技术累站

做一个职业的酋长-访ECHO

ITbulo.com  ALexa世界排名2万4000名 日访问IP4-5W 日PV20-22W站长echo,80年代生人.01年开始做个人主页,02年开始从事互联网方面的工作,一直到今天.目前正专职运营IT部落网站. 阻击者:晚上好,好久没聊了呵呵,你还记得你的第一个个人主页做的是什么内容么?第一个网站又是在什么样子的情况下诞生的?Echo:第一个个人主页"潇潇雨吧",断断续续做了近5年,最开始是以文学方面为主的,后来经过3次大的改版,最后形成了一个以网页相关教程.资源为主的技术累站

php中echo &amp;lt;&amp;lt;&amp;lt; 的应用

<?$a="变量的值将被带入";echo <<< help<pre>    php中echo <<< 的应用    虽然echo "...";可以断行,但若其中如出现",则仍需做转义处理.需写做:    echo "    aaaa\"uiuie\"    ...    ";    而使用echo <<< 则可免去这个麻烦.    书写格式:  

PHP自带可以代替echo调试的unit函数

今天发现个函数 assert 和 assert_options, 他们组合可以完成一个简单的phpunit的功能, 但是实在是太简单, 所以用处不太大, 但是还是记录一下好了. 主要问题是不能灵活的自己定义错误的提示信息,只能提示出问题的文件和行数. 具体的使用方法可以看 <> 或者 <> 同时可以结合 <>中 "XXVII. Error Handling and Logging Functions" 章节里的东西,共同使用. 下面是我写的一个测试文