Why not adopt me?
NAME
RPC::ToWorker - invoke remote perl functions asynchronously on remote systems
SYNOPSIS
use RPC::ToWorker;
do_remote_job(
prefix => '#output prefix',
chdir => '/some/directory',
host => 'some.host.name',
data => $data_to_send,
preload => [qw(List::Of Required::Modules )],
desc => 'remote job description',
eval => 'my ($data) = @_; code_to_run(); return(@values)',
when_done => sub { my (@values) = @_; },
all_done => \&callback_for_slave_process_is_finished,,
error_handler => \&callback_for_STDERR_output_from_slave,
output_handler => \&callback_for_STDOUT_output_from_slave,
);
IO::Event::loop;
DESCRIPTION
RPC::ToWorker provides a way to invoke a perl function on a remote system. It starts the remote perl process, passes data to it, and runs arbitrary code. It does this all with asynchronous IO (using <IO::Event>) so that multiple processes can run at the same time.
The slave job on the remote system can also invoke functions in the master process using master_call
in RPC::ToWorker::Callback.
PARAMETERS
- host
-
Required. The remote hostname.
- eval
-
Required. Code to eval on the remote host. Return values will be passed to
when_done
code reference. - when_done
-
Required. Code reference to invoke with the return values from the
eval
. - data
-
Data reference to pass to the remote process. It will be marshalled with Storable.
- chdir
-
Directory to
chdir()
to before doing anything else. - desc
-
Text (short) description of the remote job for error messages.
- prefix
-
String to prefix each line of output from the slave with. Defaults to
host:
. - preload
-
Modules to load, a list.
- prequel
-
Code to eval prior to the main eval. Cannot
return
. - error_handler($ioe)
-
This is currently disabled Code reference to call when there is STDERR output from the slave process. The default handler prints the output to STDOUT prefixed with
prefix
.$ioe
is an IO::Event object so you can loop over it like a normal file descriptor. - output_handler($ioe)
-
Code reference to call when there is STDOUT output from the slave process. The default handler prints the output to STDOUT prefixed with
prefix
.$ioe
is an IO::Event object so you can loop over it like a normal file descriptor. - on_failure
-
Code reference to invoke if the slave process failes to run. It may be invoked multiple times for the same slave.
- all_done
-
Code reference to invoke when the slave process is fully shut down.
- local_data
-
A hash of data that can be made available to
master_call()
invocations. - can_retry
-
Can this job be re-attempted? Defaults to 1.
LICENSE
This package may be used and redistributed under the terms of either the Artistic 2.0 or LGPL 2.1 license.