≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 网络编程 > PHP笔记

PHP echo输出内容过多会很慢原因分析

人气:768 时间:2018-09-25

这篇文章主要为大家详细介绍了PHP echo输出内容过多会很慢原因分析,具有一定的参考价值,可以用来参考一下。

对PHP的echo输出内容过多会很慢感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!
作为一个行走江湖多年的老中医,今天受命去解决一例前端页面展现缓慢的问题。问题页的情况如下:
apache + php
使用smarty模板输出内容
页面最终输出内容较大,80k+
页面执行时间在500ms以上

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

于是猛力使用搜索技能,最终在php手册的echo部分找到了一些蛛丝马迹,早在2003年就有前辈认为通过echo输出大字符串到客户端会引起服务器的性能问题,据我测试,在这个场景下使用print其实也是一样的慢。

建议的解决办法是把字符串切割成更小的字符串输出,展现速度会有提升,输出函数如下:

/**
* PHP的echo输出内容过多会很慢
*
* @param 
* @arrange 512-笔记网: q1010.com
**/
<?php
//对大字节字符串进行分割保存到数组中,然后循环输出
function echoBigChar($string,$bufferSize=8192){
$splitString=str_split($string,$bufferSize);
foreach($splitString as $chunk){
echo $chunk;
}
}
/***   来自四海网(www.q1010.com)   ***/
但是上面的处方不太对症,整个echobig的输出时间仍然在400毫秒左右,没有太大改善。考虑到是输出大量内容到客户端比较慢,于是检查了apache的配置,原来还没打开deflate进行压缩,遂启用之。再次使用xhprof进行检查,这条echo的输出时间降低到5ms左右。400ms到5ms,一个配置问题会产生80倍的差距,还真是省老钱了。

这个故事告诉我们,开启压缩输出真的很重要。

本文来自:http://www.q1010.com/173/1412-0.html

注:关于PHP echo输出内容过多会很慢原因分析的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:echo

您可能感兴趣的文章

  • PHP 几个输出函数echo(),print(),print_r()区别解析
上一篇:PHP 数字格式化,数字每三位加逗号的简单示例
下一篇:php 在数组中查找某个值是否存在(in_array(),array_search(),array_key_exists())
热门文章
  • PHP 写入WRITE编码为UTF8的文件示例
  • PHP 中文字符串截取函数示例:支持gb2312,gbk,big
  • PHP 简单留言板的制作示例
  • 解决Fatal error: Call to undefined function mb_convert_encoding() in错误问题
  • PHP语言基础(标记、注释、变量、数组、常量、函数)示例
  • php 生成迅雷链接的简单示例
  • php 获取短网址的实现方法
  • PHP 通用分页类的简单示例
  • PHP 使用文件方式导入导出整个MYSQL数据库的实现方法
  • php 获取MYSQL错误的简单示例
  • 最新文章
    • 解决PHP使用redis实现统计缓存MySQL压力的问题
    • php 简单的上传进度条的简单示例
    • php 给html中引用的js和css路径打上版本号的实现方法
    • php 实现计算年龄精准到年月日的实例
    • php+ajax无刷新分页的简单示例
    • 解决php+ajax无刷新上传图片的问题
    • 解决PHP生成HTML静态页面的问题
    • 解决PHP使用uniqid函数生成唯一ID的问题
    • 解决PHP防刷票的一些问题
    • 微信access_token的获取开发的实现方法

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。