Parallel::Forker - Parallel job forking and management
use Parallel::Forker; $Fork = new Parallel::Forker; $SIG{CHLD} = sub { Fork::sig_child($Fork); }; $SIG{TERM} = sub { $Fork->kill_tree_all('TERM') if $Fork; die "Quitting...\n"; }; $Fork->schedule(run_on_start => sub {print "starting...";}, run_on_finish => sub {print "done...";}, ) ->run(); $Fork->wait_all(); # Wait for all children to finish # More processes my $p1 = $Fork->schedule(...)->ready(); my $p2 = $Fork->schedule(..., run_after=>[$p1])->ready(); $Fork->wait_all(); # p1 will complete before p2 starts # Other functions $Fork->poll(); # Service any active children foreach my $proc ($Fork->running()) { # Loop on each running child
Parallel::Forker manages parallel processes that are either subroutines or system commands. Forker supports most of the features in all the other little packages out there, with the addition of being able to specify complicated expressions to determine which processes run after others, or run when others fail.
Function names loosely based on Parallel::ForkManager.
The unique property of Parallel::Forker is the ability to schedule processes based on expressions that are specified when the processes are defined. For example:
my $p1 = $Fork->schedule(..., label=>'p1'); my $p2 = $Fork->schedule(..., label=>'p2'); my $p3 = $Fork->schedule(..., run_after => "p1 | p2"); my $p4 = $Fork->schedule(..., run_after => "p1 & !p2");
Process p3 is specified to run after process p1 *or* p2 have completed successfully. Process p4 will run after p1 finishes successfully, and process p2 has completed with bad exit status.
For more examples, see the tests.
Return a Parallel::Forker::Process objects for the given named process, or undef if not found.
Return true if any processes are running, or runnable (need to run).
Send a kill to all running children.
Send a kill to all running children and their subchildren.
Specify the maximum number of processes to run at any one time. Defaults to undef, which runs all possible jobs at once.
Create a new manager object. There may be more then one manager in any application.
See if any children need work, and service them. Non-blocking; always returns immediately.
Return Parallel::Forker::Process objects for all processes.
Return Parallel::Forker::Process objects for all processes, in name sorted order.
Mark all processes as ready for scheduling.
Return Parallel::Forker::Process objects for an processes that are currently running.
Register a new process perhaps for later running. Returns a Parallel::Forker::Process object. Parameters are passed by name as follows:
Optional name to use in run_after commands. Unlike name, this may be reused, in which case run_after will wait on all commands with the given label.
Optional name to use in run_after commands. Note names MUST be unique! When not specified, a unique number will be assigned automatically.
Subroutine reference to execute when the job begins. Executes under the forked process.
Subroutine reference to execute when the job ends. Executes on the master process.
A list reference of processes that must be completed before this process can be runnable. You may pass a process object (from schedule), a process name, or a process label. You may use "|" or "&" in a string to run this process after a OR of any processes exit, or after ALL exit (the default.) ! in front of a process name indicates to run if that process fails with bad exit status. ^ in front of a process indicates to run if that process succeeds OR fails.
Must be called in SIG{CHLD} handler by the parent process. If there are multiple Parallel::Forker's each of their sig_child's must be called.
Wait for all running jobs to complete.
Print a dump of the execution tree.
The latest version is available from CPAN and from http://www.veripool.com/.
Copyright 2002-2007 by Wilson Snyder. This package is free software; you can redistribute it and/or modify it under the terms of either the GNU Lesser General Public License or the Perl Artistic License.
Wilson Snyder <wsnyder@wsnyder.org>
Parallel::Forker::Process
To install Parallel::Forker, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Parallel::Forker
CPAN shell
perl -MCPAN -e shell install Parallel::Forker
For more information on module installation, please visit the detailed CPAN module installation guide.