J'ai remarqué un délai d'environ 120 secondes entre la gestion des événements response_data
et response_done
en WWW::Mechanize
avec un site Web https donné. J'ai vérifié avec un navigateur Web normal et ne pas éprouver cette lenteur ainsi je soupçonne qu'il y a quelque chose que je dois faire mal.Perl LWP :: UserAgent se bloque pendant 120 secondes apparemment de manière aléatoire contre un serveur donné
Voici ce que je faisais de retracer les événements (pour une raison use LWP::Debug qw(+)
ne rien faire):
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
}
);
Et voici un extrait des traces (les URL et les cookies sont brouillées):
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 ===
Au cours des messages «Got response data chunk» et «BEGIN HTTP RESPONSE», vous pouvez voir un intervalle de 121,5 secondes. J'ai le sentiment que parfois LWP::UserAgent
se bloque pendant deux minutes après avoir reçu la totalité des données.
Avez-vous la moindre idée d'où cela pourrait provenir?
EDIT est ici une capture d'écran dans Wireshark: Je reçois le FIN/message ACK après 120 secondes ...
Merci
La documentation de 'LWP :: Debug' dit ceci: * LWP :: Debug utilisé pour fournir des fonctions de traçage, mais celles-ci ne sont plus utilisées par LWP * – Borodin
@Borodin: Merci, ça répond à un autre problème :) – Benoit