Perl有多处理模块吗?与Python multiprocessing module提供的功能类似的东西。
我知道我可以使用Perl构建类似的功能,但我正在寻找已经实现的功能。
答案 0 :(得分:11)
我认为Forks::Super
非常接近。它具有一些功能,用于在后台进程中运行任意子例程(或外部命令),监视和发出后台进程信号,并使进程间通信不那么痛苦。
use Forks::Super;
sub do_something { my @args = @_; ... }
$process = fork { sub => \&do_something, args => [@args] };
$process->wait;
my $x = 42;
my @y = ();
my %z = ();
sub do_something_else {
$x = 19;
@y = qw(foo bar);
%z = (foo => 'bar');
}
$process = fork { sub => 'do_something_else', share => [\$x, \@y, \%z ] };
$process->wait;
# $x, @y, and %z are now updated with changes made in background process
# create your own pipes to use for IPC
use IO::Handle;
pipe my $child_read, my $parent_write;
pipe my $parent_read, my $child_write;
$parent_write->autoflush(1);
$child_write->autoflush(1);
sub square {
while (my $x = <$child_read>) {
print {$child_write} $x ** 2, "\n";
}
close $child_write;
}
$process = fork { sub => 'square' };
print {$parent_write} "9\n";
my $result = <$parent_read>; # should be "81\n";
close $parent_write;
# or use the standard I/O handles for IPC
sub square_root {
sleep 1 && seek STDIN,0,1 while eof(STDIN); # ok, this is a workaround for an existing bug :-(
while (my $x = <STDIN>) {
print sqrt($x), "\n";
}
}
$process = fork { sub => 'square_root', child_fh => 'in,out,block' };
$process->write_stdin("81\n");
$result = $process->read_stdout(); # => "9\n"
multiprocessing
模块和Forks::Super
都有很多功能。您对哪些人特别感兴趣?
我是Forks::Super
的作者,我的目标是包含人们觉得有用的并行处理功能,所以如果你想在Perl中使用multiprocessing
中有一个功能,请告诉我。
答案 1 :(得分:11)
forks提供与threads相同的强大界面,但使用进程而不是线程。
use forks; # Or: use threads;
use Thread::Queue;
my $q = Thread::Queue->new();
my @workers;
for (1..NUM_WORKERS) {
push @workers, async {
while (defined(my $job = $q->dequeue())) {
...
}
};
}
$q->enqueue(...);
$q->enqueue(undef) for @workers;
$_->join for @workers;
比较福克斯叉子::超级。
请记住,这些假设是Forks :: Super擅长的情况!
use Forks::Super;
sub do_something { my @args = @_; ... }
$process = fork { sub => \&do_something, args => [@args] };
$process->wait;
可以写成
use forks;
sub do_something { my @args = @_; ... }
$process = async { do_something(@args) };
$process->join;
---
use Forks::Super;
my $x = 42;
my @y = ();
my %z = ();
sub do_something_else {
$x = 19;
@y = qw(foo bar);
%z = (foo => 'bar');
}
$process = fork { sub => 'do_something_else', share => [\$x, \@y, \%z ] };
$process->wait;
可以写成
use forks;
use forks::shared;
my $x :shared = 42;
my @y :shared = ();
my %z :shared = ();
sub do_something_else {
$x = 19;
@y = qw(foo bar);
%z = (foo => 'bar');
}
$process = async { do_something_else() };
$process->join;
---
use Forks::Super;
use IO::Handle;
pipe my $child_read, my $parent_write;
pipe my $parent_read, my $child_write;
$parent_write->autoflush(1);
$child_write->autoflush(1);
sub square {
while (my $x = <$child_read>) {
chomp($x);
print {$child_write} $x ** 2, "\n";
}
close $child_write;
}
$process = fork { sub => 'square' };
print { $parent_write } "9\n";
chomp( my $result = <$parent_read> ); # 81
close $parent_write;
$process->wait;
可以写成
use forks;
use Threads::Queue;
my $req = Threads::Queue->new();
my $resp = Threads::Queue->new();
sub square { $_[0] ** 2 }
$process = async {
while (defined(my $x = $req->dequeue())) {
$resp->enqueue( square($x) );
}
};
$req->enqueue(9);
my $result = $resp->dequeue(); # 81
$resp->enqueue(undef);
$process->join;
---
use Forks::Super;
sub square_root {
sleep 1 && seek STDIN,0,1 while eof(STDIN); # ok, this is a workaround for an existing bug :-(
while (my $x = <STDIN>) {
chomp($x);
print sqrt($x), "\n";
}
}
$process = fork { sub => 'square_root', child_fh => 'in,out,block' };
$process->write_stdin("81\n");
chomp( $result = $process->read_stdout() ); # 9
$process->close_fh('stdin');
$process->wait;
可以写成
use forks;
use Threads::Queue;
my $req = Threads::Queue->new();
my $resp = Threads::Queue->new();
$process = async {
while (defined(my $x = $req->dequeue())) {
$resp->enqueue( sqrt($x) );
}
};
$req->enqueue(81);
my $result = $resp->dequeue(); # 9
$resp->enqueue(undef);
$process->join;
答案 2 :(得分:3)
POE: Perl Object Environment怎么样?它支持异步子进程。
答案 3 :(得分:0)
您可以使用https://github.com/marioroy/mce-perl 它类似于python多进程模块