Here's something I wrote recently to fork 6 processes at a time (on more than 6 jobs):
#!/usr/bin/perl
use strict;
use warnings;
use Parallel::ForkManager;
my $pm = Parallel::ForkManager->new( 6 );
my %kids;
local $SIG{ INT } = sub {
print "\nCaught interrupt, shutting down...";
kill 9, keys %kids;
$pm->wait_all_children;
print "done.\n";
exit;
};
# Remove child pid from running table
$pm->run_on_finish(
sub {
my $pid = shift;
delete $kids{ $pid };
}
);
for my $job ( @jobs ) { # Whatever
if ( my $pid = $pm->start ) {
$kids{ $pid }++;
print "Started $job...\n";
}
else {
local $SIG{ INT } = sub { $pm->finish };
system( $job );
$pm->finish;
}
}
$pm->wait_all_children;
(edit) looks like I didn't reply to the parent, whoops.
Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
Read Where should I post X? if you're not absolutely sure you're posting in the right place.
Please read these before you post! —
Posts may use any of the Perl Monks Approved HTML tags:
- a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
| |
For: |
|
Use: |
| & | | & |
| < | | < |
| > | | > |
| [ | | [ |
| ] | | ] |
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.