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开发文件系统实例讲解
Oct 09 PHP
php基础知识:类与对象(5) static
Dec 13 PHP
php下使用SimpleXML 处理XML 文件
Feb 27 PHP
ThinkPHP的RBAC(基于角色权限控制)深入解析
Jun 17 PHP
php使用base64加密解密图片示例分享
Jan 20 PHP
19个超实用的PHP代码片段
Mar 14 PHP
修改WordPress中文章编辑器的样式的方法详解
Dec 15 PHP
thinkphp中字符截取函数msubstr()用法分析
Jan 09 PHP
对PHP依赖注入的理解实例分析
Oct 09 PHP
PHP设置images目录不充许http访问的方法
Nov 01 PHP
PHP bin2hex()函数基础实例讲解
Feb 11 PHP
PDO实现学生管理系统
Mar 21 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(2)
2006/10/09 PHP
php 移除数组重复元素的一点说明
2008/11/27 PHP
PHP 地址栏信息的获取代码
2009/01/07 PHP
分享一段php获取linux服务器状态的代码
2014/05/27 PHP
PHP使用Memcache时模拟命名空间及缓存失效问题的解决
2016/02/27 PHP
javascript 可以拖动的DIV(二)
2009/06/26 Javascript
jquery ready函数、css函数及text()使用示例
2013/09/27 Javascript
javascript教程之不完整的继承(js原型链)
2014/01/13 Javascript
使用CSS样式position:fixed水平滚动的方法
2014/02/19 Javascript
在linux中使用包管理器安装node.js
2015/03/13 Javascript
jQuery实现文件上传进度条特效
2015/08/12 Javascript
JavaScript实现向右伸出的多级网页菜单效果
2015/08/25 Javascript
input点击后placeholder中的提示消息消失
2016/01/15 Javascript
jQuery实现的文字hover颜色渐变效果实例
2016/02/20 Javascript
jQuery点击其他地方时菜单消失的实现方法
2016/04/22 Javascript
深入理解setTimeout函数和setInterval函数
2016/05/20 Javascript
关于Angularjs中跨域设置白名单问题
2018/04/17 Javascript
微信小程序websocket实现聊天功能
2020/03/30 Javascript
[02:39]DOTA2英雄基础教程 天怒法师
2013/11/29 DOTA
Python set集合类型操作总结
2014/11/07 Python
Python中isnumeric()方法的使用简介
2015/05/19 Python
Python Property属性的2种用法
2015/06/21 Python
详解Python设计模式编程中观察者模式与策略模式的运用
2016/03/02 Python
python读取txt文件中特定位置字符的方法
2018/12/24 Python
Python3使用PySynth制作音乐的方法
2019/09/09 Python
Python queue队列原理与应用案例分析
2019/09/27 Python
matplotlib基础绘图命令之imshow的使用
2020/08/13 Python
会计专业自我鉴定范文
2013/12/29 职场文书
镇政府副镇长群众路线专题民主生活会对照检查材料
2014/09/19 职场文书
安全生产工作汇报材料
2014/10/28 职场文书
化验室岗位职责
2015/02/14 职场文书
项目备案申请报告
2015/05/15 职场文书
患者身份识别制度
2015/08/06 职场文书
2019大学生实习报告
2019/06/21 职场文书
python解决12306登录验证码的实现
2021/04/18 Python
Python中requests库的用法详解
2022/06/05 Python