gpt4 book ai didi

perl - 我如何在执行的各个阶段进行 Perl CGI 性能测量、基准测试、时间测量?

转载 作者:行者123 更新时间:2023-12-03 17:10:56 24 4
gpt4 key购买 nike

我想了解测量 CGI Perl 代码在各个阶段的执行持续时间的技术(编码、库、配置):

  1. 启动 Perl 解释器
  2. 开始运行 Perl 代码
  3. 加载本地 Perl .pm 模块以用于例程
  4. 完成代码运行

我对 3 和 4 特别感兴趣,我不相信我对 1) 或 2) 能做多少,因为我不想尝试优化 Perl 解释器,这是我唯一能做的事情这里是将硬件升级到更快的机器和/或使用 mod_perl 而不是经典的 CGI。

通过 3) 加载本地 Perl 模块,我想测量需要多长时间,但我不确定如何编码,因为我不知道(或不确定)如何在加载之前执行代码这些模块。如果我知道,那么我会记录它们加载前的时间,然后记录它们加载后的时间并计算差异。

4)应该是最容易获得的,因为我会在执行开始时和结束时记录时间(在变量中)。

我在 stackoverflow.com 上进行了搜索并发现:

Google 搜索结果包括:

最佳答案

您可以使用 FastCGI 减少 1)。它也会减少阶段 2) 和 3)。

对于测量 3),您可以使用 BEGIN block 。示例:

use Benchmark ':hireswallclock';
my ($t0,$t1);
BEGIN {$t0 = Benchmark->new;}
use DBIx::Class;
BEGIN {$t1 = Benchmark->new;}
print "the loading took:",timestr(timediff($t1, $t0)),"\n";

Deve::NYTProf 将帮助您完成 4)。还有一些特定的模块,如 Template::Timer、CGI::Application::Plugin::DevPopup::Timing、DBIx::Class::Storage::Statistics。

关于perl - 我如何在执行的各个阶段进行 Perl CGI 性能测量、基准测试、时间测量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4400058/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com