Beefy Boxes and Bandwidth Generously Provided by pair Networks
XP is just a number
 
PerlMonks  

Re^2: Use Coro for reading EventLog on many pc's?

by gizmo_mathboy (Pilgrim)
on Mar 14, 2011 at 20:59 UTC ( #893160=note: print w/ replies, xml ) Need Help??


in reply to Re: Use Coro for reading EventLog on many pc's?
in thread Use Coro for reading EventLog on many pc's?

Thank you much. That helped speed things up.

Now to re-read the docs for threads to figure out how to limit the number of threads I have so I don't saturate my network connection. I initially was looking at Thread:Queue but I wasn't understanding it properly. Maybe with this bit of helpful knowledge I can grok the docs.

gizmo


Comment on Re^2: Use Coro for reading EventLog on many pc's?
Re^3: Use Coro for reading EventLog on many pc's?
by ikegami (Pope) on Mar 14, 2011 at 21:03 UTC

    Thread::Queue is indeed the way to go.

    my $q = Thread::Queue->new(); my @threads; for (1..MAX_WORKERS) { push @threads, async { while (my $job = $q->dequeue()) { do_job($job); } }; } # Give work to the workers. for my $job (...) { $q->enqueue($job); } # Signal the workers to exit. $q->enqueue(undef) for 1..MAX_WORKERS; # Wait for the workers to finish. $_->join() for @threads;

Log In?
Username:
Password:

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://893160]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this? | Other CB clients
Other Users?
Others pondering the Monastery: (12)
As of 2014-07-22 13:25 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    My favorite superfluous repetitious redundant duplicative phrase is:









    Results (113 votes), past polls