smarty模板嵌套之include与fetch性能测试


Posted in PHP onDecember 05, 2010

方法一、使用在父模板中使用{include file="child.tpl"}直接将子模板包含进来

优点:

1、有利于模块的划分和模板的重用。

2、嵌套层次不多的时候,模板的结构清晰,一眼过去就知道这个模板的内容和结构。

3、只需要一个smarty实例就能做完所有的事情,减少系统资源的占用。

不足:

1、子模板中的变量可能与父模板的变量发生冲突

2、多重嵌套的时候,变量名冲突的几率增大,为所有的变量赋值的难度也加大。

3、子模板的可操控性差,例如不能通过设置$cache_id, $compile_id,来得到多个结果。

4、扩展性差。如果需要添加新的模板的时候需要修改模板,同时还需要修改程序。

方法二、通过$smarty->fetch()将子模板的数据当成变量assign到父模板中

优点:

1、同样有利于模块的划分,模板的重用

2、模板的结构同样清晰

3、子模板作为单独的对象,可操控性强

4、扩展性较好 

5、每个子模板都是单独的对象,不会出现变量名冲突的问题

不足:

1、如果子模板多的时候,需使用多个smarty实例来实现,PHP代码显得臃肿

2、占用较多的系统资源

3、......

在那个的时候,出于对性能的要求,以及在没有测试的情况下,想当然的认为include的性能一定就比fetch的性能要高,所有本人使用include这个方法,结果随着系统功能的不断的增加,感觉到越写越复杂,这有很大一部分原因是设计的问题,但是模板间的嵌套也是问题之一,于是回过头来考虑使用fetch这个方法。在重新做出决定之前对这个方法的性能做了测试,分别对单个模板的情况下和多个模板的情况进行测试

单个子模板测试:

有三个页面test1.php,test2.php,test3.php。这三个页面都输出同样的内容。test1.php的模板没有嵌套,test2.php的模板使用了一次include,test3.php使用fetch来实现子模板的嵌套。使用apache自带的ab测试访问各个页面所需要的平均时间(单位:ms)

第一次测试时,使用ab -n 10000 对以上三个页面进行10次,每次累计10000个访问,结果如下。

ab -n 10000 test1.php test2.php test3.php test2/test1 test3/test1
1 5.178 5.442 6.097 1.050984936 1.177481653
2 5.253 5.972 6.027 1.136874167 1.147344375
3 5.223 6.039 5.987 1.156232051 1.146276087
4 5.533 5.997 6.02 1.083860474 1.08801735
5 5.557 6.308 6.03 1.135144862 1.085117869
6 5.248 6.002 5.998 1.14367378 1.142911585
7 5.211 5.933 6.003 1.138553061 1.151986183
8 5.303 6.031 6.048 1.137280784 1.140486517
9 5.213 5.923 6.033 1.136197967 1.15729906
总计 47.719 53.647 54.243 1.124227247 1.136717031

第二次测试时,使用ab -n 100000 对以上三个页面进行1次,每次累计100000个访问,结果如下。

ab -n 100000 test1.php test2.php test3.php test2/test1 test3/test1
1 5.723 7.874 8.55 1.375851826 1.493971693

第一次测试的数据中,test1和test2的波动比较明显,test3则比较稳定,这个现象让我感到十分的奇怪。从平均数据来看,测试结果还是在预期之内的,test1的性能最好,test2比test1多耗费了12.42%的时间,test3比test1多耗费了13.67%的时间,但是test2和test3之间的差距并不大,仅仅只有1.3%左右的差别。

第二次测试的结果,三个页面的执行时间比为1:1.37:1.49,奇怪的是这次的波动更大。。。

多个子模板测试:

同样有三个页面test1.php,test2.php,test3.php。这三个页面都输出同样的内容。test1.php的模板没有嵌套,test2.php的模板使用了10次include嵌入了10个子模板,test3.php使用10次fetch嵌入了10个子模板。使用apache自带的ab测试访问各个页面所需要的平均时间(单位:ms)

因为时间的关系我只进行了一次ab -n 50000的测试,数据如下

ab -n 50000 test1.php test2.php test3.php test2/test1 test3/test1
1 5.68 6.054 6.028 1.06584507 1.061267606

 

虽然测试的方法和工具可能不是很好,但是通过这些数据的对比,在实际的应用中到底要采用哪种方法,我想大家应该心里有底了吧。

不足和错误之处还望指出,希望大家能多讨论多交流。

PHP 相关文章推荐
php中获取指定IP的物理地址的代码(正则表达式)
Jun 23 PHP
匹配csdn用户数据库与官方用户的重合度并将重叠部分的用户筛选出来
Dec 25 PHP
PHP 之Section与Cookie使用总结
Sep 14 PHP
关于查看MSSQL 数据库 用户每个表 占用的空间大小
Jun 21 PHP
基于PHP的简单采集数据入库程序【续篇】
Jul 30 PHP
php隐藏IP地址后两位显示为星号的方法
Nov 21 PHP
ThinkPHP控制器详解
Jul 27 PHP
php简单实现短网址(短链)还原的方法(测试可用)
May 09 PHP
PHP使用PHPExcel实现批量上传到数据库的方法
Jun 08 PHP
php微信公众号开发之欢迎老朋友
Oct 20 PHP
Yii2框架自定义类统一处理url操作示例
May 25 PHP
关于laravel模板中生成URL的几种模式总结
Oct 18 PHP
php 学习资料零碎东西
Dec 04 #PHP
PHP访问MYSQL数据库封装类(附函数说明)
Dec 04 #PHP
PHP验证码类代码( 最新修改,完全定制化! )
Dec 02 #PHP
PHP项目开发中最常用的自定义函数整理
Dec 02 #PHP
PHP自动选择 连接本地还是远程数据库
Dec 02 #PHP
Mysql数据库操作类( 1127版,提供源码下载 )
Dec 02 #PHP
PHP分页函数代码(简单实用型)
Dec 02 #PHP
You might like
PHP循环函数使用介绍之PHP基础入门教程
2013/09/21 PHP
php中字符串和正则表达式详解
2014/10/23 PHP
Symfony模板的快捷变量用法实例
2016/03/17 PHP
php 实现进制相互转换
2016/04/07 PHP
CI框架附属类用法分析
2018/12/26 PHP
Extjs gridpanel 出现横向滚动条问题的解决方法
2011/07/04 Javascript
jQuery让控件左右移动的三种实现方法
2013/09/08 Javascript
深入浅析AngularJS中的module(模块)
2016/01/04 Javascript
基于Jquery插件实现跨域异步上传文件功能
2016/04/26 Javascript
JS中使用变量保存arguments对象的方法
2016/06/03 Javascript
JS 获取HTML标签内的子节点的方法
2016/09/21 Javascript
详解Chai.js断言库API中文文档
2018/01/31 Javascript
解析Vue.js中的组件
2018/02/02 Javascript
浅谈angularJs函数的使用方法(大小写转换,拷贝,扩充对象)
2018/10/08 Javascript
vue中v-text / v-html使用实例代码详解
2019/04/02 Javascript
JS通过ajax + 多列布局 + 自动加载实现瀑布流效果
2019/05/30 Javascript
vue 实现滚动到底部翻页效果(pc端)
2019/07/31 Javascript
JS+CSS实现随机点名(实例代码)
2019/11/04 Javascript
jenkins自动构建发布vue项目的方法步骤
2021/01/04 Vue.js
[01:18]DOTA2超级联赛专访hanci ForLove淘汰感言曝光
2013/06/04 DOTA
[00:30]塑造者的传承礼包-戴泽“暗影之焰”套装展示视频
2014/04/04 DOTA
[05:17]DOTA2誓师:今天我们在这里 明天TI4等我!
2014/03/26 DOTA
[45:25]完美世界DOTA2联赛循环赛 PXG vs IO 第一场 11.06
2020/11/09 DOTA
python检测远程服务器tcp端口的方法
2015/03/14 Python
pandas中apply和transform方法的性能比较及区别介绍
2018/10/30 Python
Python3爬虫学习入门教程
2018/12/11 Python
python中用logging实现日志滚动和过期日志删除功能
2019/08/20 Python
JupyterNotebook 输出窗口的显示效果调整方法
2020/04/13 Python
python实现视频压缩功能
2020/12/18 Python
Expedia挪威官网:酒店、机票和租车
2018/03/03 全球购物
预备党员党课思想汇报
2014/01/13 职场文书
《自选商场》教学反思
2014/02/14 职场文书
物流管理专业自荐信
2014/06/23 职场文书
2014年大学生社会实践自我鉴定
2014/09/26 职场文书
好段摘抄大全(48句)
2019/08/08 职场文书
Linux安装apache服务器的配置过程
2021/11/27 Servers