私は perl のThread::Queueモジュールを使用して、作業中の単純なクローラーの URL をダウンロードするためにスレッドのプールをビジー状態に保ちます。を使用してThread::Queue
、ハッシュ参照 (正確には 360) のリストをキューに入れます。各ハッシュには、個々の URL に関する情報が保持されます。
#set up thread queue
my $THREADS=30; # Number of threads
my $url_q = Thread::Queue->new(); # Work to do
my $url_arr = urls();
my $count = 0;
for(@$url_arr) {
print "ENQUEUEING $_->{'url'}\n";
$url_q->enqueue($_);
$count++;
}
print "COUNT $count\n";
print "QUEUE COUNT " . $url_q->pending() . "\n";
threads->create( sub {
while(my $url_h = $url_q->dequeue()) {
print "url: $url_h->{'url'}\n\n";
print "PENDING: " . $url_q->pending() . "\n";
process_url($url_h);
}
}) for (1..$THREADS);
$url_q->end;
print "WAITING\n";
$_->join() for threads->list;
print "DONE WAITING\n";
問題は、360 個の URL がすべてエンキューされていることですが、保留中の数が 260 前後にしか落ちていないことです。私が Thread::Queue でやっている問題はありますか? ありがとう!