Как я могу использовать `pipe` для облегчения межпроцессного взаимодействия в Perl? - PullRequest
3 голосов
/ 01 апреля 2010

Может кто-нибудь объяснить, как я могу успешно связать свои процессы? Я считаю, что perldoc на IPC сбивает с толку.

То, что я имею до сих пор:

$| = 1;
$SIG{CHLD} = {wait};
my $parentPid = $$;

if ($pid = fork();) ) {
    if ($pid == 0) {
       pipe($parentPid, $$);
       open PARENT, "<$parentPid";
       while (<PARENT>) {
           print $_;
       }
       close PARENT;
       exit();
    } else {

       pipe($parentPid, $pid);
       open CHILD, ">$pid";
          or error("\nError opening: childPid\nRef: $!\n");
       open (FH, "<list")
          or error("\nError opening: list\nRef: $!\n");

       while(<FH>) {
          print CHILD, $_;
       }

       close FH
          or error("\nError closing: list\nRef: $!\n");
       close CHILD
          or error("\nError closing: childPid\nRef: $!\n);
    } else {
    error("\nError forking\nRef: $!\n");
}
  • Первое: что означает труба perldoc под READHANDLE, WRITEHANDLE?

  • Второе: могу ли я реализовать решение, не полагаясь на CPAN или другие модули?

альтернативный текст http://www.wellho.net/slideshow/plx8.jpg

1 Ответ

5 голосов
/ 01 апреля 2010

Вот упрощенный пример, основанный на коде, найденном в perldoc perlipc :

#!/usr/bin/perl

use strict; use warnings;

$SIG{CHLD} = sub { wait };

pipe my $reader, my $writer;

my $pid = fork;
defined $pid or die "fork failed: $!";

if ( $pid ) { # parent
    close $reader;
    for my $n ( 1 .. 5 ) {
        select $writer;
        $| = 1;
        print $writer "Message $n\n"
            or die "Failed to pass message to child: $!";
        sleep 1;
    }
    close $writer;
    exit;
}
else { # child
    close $writer;
    while ( my $msg = <$reader> ) {
        print "Child received: $msg";
        last if rand > 0.5; # to check error handling in parent
    }
    close $reader;
    exit;
}
...