perl – 有效处理lwp超时

我正在使用LWP从网页下载内容,我想限制等待页面的时间.这是在lwp中完成的,如下所示:
my $ua = LWP::UserAgent->new;
$ua->timeout(10);
$ua->get($url);

这样可以正常工作,除非超时达到极限,它就会死掉,我无法继续使用脚本!我真的很想妥善处理这个超时,这样我就可以记录url超时然后转到下一个.有谁知道如何做到这一点?谢谢!

解决方法

LWP::Agent的get()返回一个可用于检查错误HTTP::Response对象:
use LWP::Agent;
use HTTP::Status ();

my $ua = LWP::UserAgent->new;
$ua->timeout(10);
my $response = $ua->get($url);

if ($response->is_error) {
    printf "[%d] %s\n",$response->code,$response->message;

    # record the timeout
    if ($response->code == HTTP::Status::HTTP_Request_TIMEOUT) {
        ...
    }
}

顺便说一句,现在更好的做法是使用Try::Tiny而不是eval {…}.它让你尝试{…} catch {…}.它解决了检查$@的问题(参见Try :: Tiny文档中的背景部分).

相关文章

1. 如何去重 #!/usr/bin/perl use strict; my %hash; while(...
最近写了一个perl脚本,实现的功能是将表格中其中两列的数据...
表的数据字典格式如下:如果手动写MySQL建表语句,确认麻烦,...
巡检类工作经常会出具日报,最近在原有日报的基础上又新增了...
在实际生产环境中,常常需要从后台日志中截取报文,报文的形...
最近写的一个perl程序,通过关键词匹配统计其出现的频率,让...