如何在 Template::Toolkit 中分析模板性能?

Posted

技术标签:

【中文标题】如何在 Template::Toolkit 中分析模板性能?【英文标题】:How can I profile template performance in Template::Toolkit? 【发布时间】:2010-09-22 04:46:56 【问题描述】:

在使用Template::Toolkit 时,对我的各种模板的性能进行基准测试的最佳方法是什么?

我想要一些可以分解处理每个块或模板文件所花费的 cpu/系统时间的东西,不包括处理其中其他模板所花费的时间。例如,Devel::DProf 对此毫无用处,因为它只是告诉我在 Template 模块的各种内部方法中花费了多少时间。

【问题讨论】:

【参考方案1】:

事实证明,谷歌搜索 template::toolkit profiling 产生了最好的结果,来自November 2005 by Randal Schwartz 的一篇文章。由于版权问题,我无法在此处复制和粘贴任何文章,但可以说您只需获取his source 并将其用作模板后的模块,如下所示:

use Template;
use My::Template::Context;

当你的脚本运行时,你会得到这样的输出到 STDERR:

-- info.html 于 2008 年 11 月 13 日星期四 09:33:26: cnt clk 用户 sys cuser csys 模板 1 0 0.06 0.00 0.00 0.00 动作.html 1 0 0.00 0.00 0.00 0.00 横幅.html 1 0 0.00 0.00 0.00 0.00 common_javascript.html 1 0 0.01 0.00 0.00 0.00 日期时间.html 1 0 0.01 0.00 0.00 0.00 diag.html 3 0 0.02 0.00 0.00 0.00 字段表 1 0 0.00 0.00 0.00 0.00 header.html 1 0 0.01 0.00 0.00 0.00 信息.html 1 0 0.01 0.01 0.00 0.00 my_checklists.html 1 0 0.00 0.00 0.00 0.00 my_javascript.html 1 0 0.00 0.00 0.00 0.00 qualifier.html 52 0 0.30 0.00 0.00 0.00 推荐选项 1 0 0.01 0.00 0.00 0.00 关系块 1 0 0.00 0.00 0.00 0.00 set_bgcolor.html 1 0 0.00 0.00 0.00 0.00 shared_javascript.html 2 0 0.00 0.00 0.00 0.00 表块 1 0 0.03 0.00 0.00 0.00 ticket.html 1 0 0.08 0.00 0.00 0.00 ticket_actions.html - 结尾

请注意,列出了块以及单独的文件。

恕我直言,这比 CPAN 模块 Template::Timer 有用得多。

【讨论】:

以上是关于如何在 Template::Toolkit 中分析模板性能?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Ruby 中分析 `require` 语句?

如何在 PhantomJS 中分析 javascript

如何在生产环境中分析请求?

如何在 Ruby on Rails 中分析请求?

如何在 Android Studio 中分析测试?

如何在 Python 中分析异常处理?