使用Perl代码获取访问网页的载入时间
2012-08-07 23:47
405 查看
接到同事的需求,说是需要做个脚本,输出访问网页的速度。考虑到也就Perl比较熟,就上网搜了搜模块。
先用的是Benchmark,大体上是先两个时间戳,然后相减:
use Benchmark;
my $timestamp1 = Benchmark->new;
#code
my $timestamp2 = Benchmark->new;
my $time_run = timediff($timestamp1 ,$timestamp2);
print timestr($time_run);
但是输出结果是以秒为单位的,显然这个是无法接受的;
然后又上网,找到一个Time::HiRes这个模块,可以支持到毫秒,网页读取就用的是LWP,代码如下:
#!perl -w
use strict;
use LWP::UserAgent;
use Time::HiRes qw (time gettimeofday tv_interval);
my $get_page = LWP::UserAgent->new;
$get_page ->timeout(100);
my $response = '';
my $webaddr = "http://www.anjuke.com";
my $t0 = [gettimeofday];
$response = $get_page ->get($webaddr);
#my $prop_detail_page = $response ->content;
my $t1 = [gettimeofday];
my $elapsed = tv_interval($t0,$t1);
print $elapsed;
大体是反应出网页读取的速度了。后面没有考虑到图片等的加载,这个需要改进一下。
大概思路是先提取网页内容,再从内容中用正则提取出各图片,然后计算图片下载所花的时间;
因为浏览器提取网页肯定是多线程,所以Perl上也要模拟多线程。
不过目前测试的结果来看,现在这个输出结果,大体上还是能够反映网速情况的~
先用的是Benchmark,大体上是先两个时间戳,然后相减:
use Benchmark;
my $timestamp1 = Benchmark->new;
#code
my $timestamp2 = Benchmark->new;
my $time_run = timediff($timestamp1 ,$timestamp2);
print timestr($time_run);
但是输出结果是以秒为单位的,显然这个是无法接受的;
然后又上网,找到一个Time::HiRes这个模块,可以支持到毫秒,网页读取就用的是LWP,代码如下:
#!perl -w
use strict;
use LWP::UserAgent;
use Time::HiRes qw (time gettimeofday tv_interval);
my $get_page = LWP::UserAgent->new;
$get_page ->timeout(100);
my $response = '';
my $webaddr = "http://www.anjuke.com";
my $t0 = [gettimeofday];
$response = $get_page ->get($webaddr);
#my $prop_detail_page = $response ->content;
my $t1 = [gettimeofday];
my $elapsed = tv_interval($t0,$t1);
print $elapsed;
大体是反应出网页读取的速度了。后面没有考虑到图片等的加载,这个需要改进一下。
大概思路是先提取网页内容,再从内容中用正则提取出各图片,然后计算图片下载所花的时间;
因为浏览器提取网页肯定是多线程,所以Perl上也要模拟多线程。
不过目前测试的结果来看,现在这个输出结果,大体上还是能够反映网速情况的~
相关文章推荐
- JSON使用——获取网页返回结果是Json的代码
- 用Java线程获取优异性能(II)——使用同步连载线程访问关键代码部份
- 【2011.09.01】如何使用javaScript代码获取系统时间和日期?
- 使用vb获取网页源文件并保存的简单代码
- 使用NTP协议获取网络时间代码
- 用Java线程获取优异性能(II)——使用同步连载线程访问关键代码部份
- 用Java线程获取优异性能(II)——使用同步连载线程访问关键代码部份
- 使用golang获取linux上文件的访问/创建/修改时间
- Swift - 使用Contacts访问通讯录1(纯代码获取联系人)
- 【perl】使用LWP获取带cookie验证的HTTPS网页
- perl获取日期与时间的实例代码
- 用Java线程获取优异性能(II)——使用同步连载线程访问关键代码部份
- cookie获取游览器的上次访问时间的代码
- 获取CPU时间戳代码 使用CPU时间戳进行高精度计时
- Perl使用File::Basename获取文件扩展名的代码
- 使用libcurl 函数库获取网页数据代码
- 使用JAVA代码通过SSH访问远程windows,获取磁盘信息
- 用Java线程获取优异性能(II)——使用同步连载线程访问关键代码部份
- 使用HttpWebRequest访问网页及获取数据
- 使用IdHttp获取网页代码出现的问题,只能得到部分代码,为什么,请大家帮忙