次のサブルーチンを使用して、40 ほどのスレッドを実行しています。
my $app = shift;
my $ua = LWP::UserAgent->new();
$ua->timeout(5);
my $response = $ua->get($$app{'watch_url'});
my $new_md5;
if ($response->is_success()) {
$new_md5 = md5_hex($response->content());
}
return ($$app{'short_name'}, $$app{'watch_md5'}, $new_md5);
約 3/4 の時間でコア ダンプが発生します。LWP と LWP::UserAgent は純粋な Perl であるため、私はこれに油断しています。LWP::UserAgent はスレッドセーフではありませんか?
アップデート:
問題を再現するための最小バージョンは次のとおりです。
use strict;
use warnings;
use threads;
use LWP::UserAgent;
sub check_app {
my $ua = LWP::UserAgent->new();
$ua->timeout(5);
$ua->get('http://www.flatdoc.com/?' . rand(10));
}
my @threads;
for (my $i = 0; $i < 40; $i++) {
my $thread = threads->create(\&check_app);
push(@threads, $thread);
}
foreach (@threads) {
$_->join();
}