Я заметил задержку примерно в 120 секунд между обработкой событий response_data
и response_done
в WWW::Mechanize
с указан https веб-сайт. Я проверил с помощью обычного веб-браузера и не заметил такой медлительности, поэтому я подозреваю, что должен что-то сделать не так.
Вот что я сделал для отслеживания событий (почему-то use LWP::Debug qw(+)
ничего не сделал) :
use WWW::Mechanize;
use Time::HiRes qw(gettimeofday);
use IO::Handle;
my $mech = WWW::Mechanize->new(
timeout => 3,
autocheck => 1, # check success of each query
stack_depth => 0, # no keeping history
keep_alive => 50, # connection pool
);
$mech->agent_alias( 'Windows IE 6' );
open my $debugfile, '>traffic.txt';
$debugfile->autoflush(1);
$mech->add_handler( request_send => sub {
my $cur_time = gettimeofday();
my $req = shift;
print $debugfile "\n$cur_time === BEGIN HTTP REQUEST ===\n";
print $debugfile $req->dump();
print $debugfile "\n$cur_time === END HTTP REQUEST ===\n";
return
}
);
$mech->add_handler( response_header => sub {
my $cur_time = gettimeofday();
my $res = shift;
print $debugfile "\n$cur_time === GOT RESPONSE HDRS ===\n";
print $debugfile $res->dump();
return
}
);
$mech->add_handler( response_data => sub {
my $cur_time = gettimeofday();
my $res = shift;
my $content_length = length($res->content);
print $debugfile "$cur_time === Got response data chunk resp size = $content_length ===\n";
return
}
);
$mech->add_handler( response_done => sub {
my $cur_time = gettimeofday();
my $res = shift;
print $debugfile "\n$cur_time === BEGIN HTTP RESPONSE ===\n";
print $debugfile $res->dump();
print $debugfile "\n=== END HTTP RESPONSE ===\n";
return
}
);
А вот выдержка из трассировки (URL и куки запутаны):
1347463214.24724 === BEGIN HTTP REQUEST ===
GET https://...
Accept-Encoding: gzip
Referer: https://...
User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)
Cookie: ...
Cookie2: $Version="1"
(no content)
1347463214.24724 === END HTTP REQUEST ===
1347463216.13134 === GOT RESPONSE HDRS ===
HTTP/1.1 200 OK
Date: Wed, 12 Sep 2012 15:20:08 GMT
Accept-Ranges: bytes
...
Server: Lotus-Domino
Content-Length: 377806
Content-Type: application/octet-stream
Last-Modified: Fri, 07 Sep 2012 06:25:33 GMT
Client-Peer: ...
Client-Response-Num: 1
Client-SSL-Cert-Issuer: ...
Client-SSL-Cert-Subject: ...
Client-SSL-Cipher: DES-CBC3-SHA
Client-SSL-Socket-Class: IO::Socket::SSL
(no content)
1347463216.48305 === Got response data chunk resp size = 4096 ===
1347463337.98131 === BEGIN HTTP RESPONSE ===
HTTP/1.1 200 OK
Date: Wed, 12 Sep 2012 15:20:08 GMT
Accept-Ranges: bytes
...
Server: Lotus-Domino
Content-Length: 377806
Content-Type: application/octet-stream
Last-Modified: Fri, 07 Sep 2012 06:25:33 GMT
Client-Date: Wed, 12 Sep 2012 15:22:17 GMT
Client-Peer: ...
Client-Response-Num: 1
Client-SSL-Cert-Issuer: ...
Client-SSL-Cert-Subject: ...
Client-SSL-Cipher: DES-CBC3-SHA
Client-SSL-Socket-Class: IO::Socket::SSL
PK\3\4\24\0\6\0\10\0\0\0!\0\x88\xBC\21Xi\2\0\0\x84\22\0\0\23\0\10\2[Content_Types].xml \xA2...
(+ 377294 more bytes not shown)
=== END HTTP RESPONSE ===
Во время сообщений «Получен фрагмент данных ответа» и «НАЧАТЬ ОТВЕТ HTTP» вы можете увидеть разрыв в 121,5 секунды. Такое ощущение, что иногда LWP::UserAgent
зависает минуты на две после получения полного объема данных.
У вас есть предположения, откуда это могло взяться?
EDIT вот скриншот в Wireshark: я получаю сообщение FIN/ACK через 120 секунд…
Спасибо
LWP::Debug
сказано следующее: LWP::Debug раньше предоставлял средства трассировки, но они больше не используются LWP - person Borodin   schedule 12.09.2012