PHP中使用echo输出内容过多会很慢

PHP 投稿 25200 1 评论

PHP中使用echo输出内容过多会很慢

解决前端页面展现缓慢的问题,问题页的情况如下:

apache + php

使用smarty模板输出内容

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

页面执行时间在500ms以上

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

于是猛力使用搜索技能,最终在php手册的echo部分找到了一些蛛丝马迹,在这个场景下使用print其实也是一样的慢。建议的解决办法是把字符串切割成更小的字符串输出,展现速度会有提升,输出函数如下:

<?php
//对大字节字符串进行分割保存到数组中,然后循环输出
function echoBigChar($string,$bufferSize=8192){
	$splitString=str_split($string,$bufferSize);
	foreach($splitString as $chunk){
		echo $chunk;
	}
}

但是上面的处方不太对症,整个echobig的输出时间仍然在400毫秒左右,没有太大改善。考虑到是输出大量内容到客户端比较慢,于是检查了apache的配置,原来还没打开deflate进行压缩,遂启用之。再次使用xhprof进行检查,这条echo的输出时间降低到5ms左右。400ms到5ms,一个配置问题会产生80倍的差距,还真是省老钱了。

再页面输出内容时,开启压缩输出很重要,节省很多资源时间。

编程笔记 » PHP中使用echo输出内容过多会很慢

赞同 (38) or 分享 (0)
游客 发表我的评论   换个身份
取消评论

表情
(1)个小伙伴在吐槽
  1. 节奏感很好。
    暗影之王 2023-09-26 22:30 (2年前) 回复