Beefy Boxes and Bandwidth Generously Provided by pair Networks
Perl-Sensitive Sunglasses
 
PerlMonks  

Re: controlling child processes

by johngg (Canon)
on Apr 04, 2006 at 23:02 UTC ( [id://541237]=note: print w/replies, xml ) Need Help??


in reply to controlling child processes

I have a script that does tape backups. It forks a child process for each tape device on the host so that multiple tape devices are written concurrently rather than consecutively. This is the skeleton of the process, which uses pipes so that the children can log messages that the parent can read later.

use IO::Pipe; ... foreach $tapeDevice (@tapeDevices) { $pipeFH = IO::Pipe->new(); ... if($pid = fork()) { # This is the parent. $pipeFH->reader(); push @pipes, $pipeFH; ... } elsif(defined $pid) { # This is the child. $pipeFH->writer(); # Do lots of stuff writing to tape ... $pipeFH->print("some message or other"); ... } else { # Fork failed for some reason. die "fork: $!\n"; } } # We have now forked a child for each tape device so # wait for our children to finish. Print exit status. while((my $returnPID = wait()) != -1) { print "Child $returnPID returned status ", $? >> 8, "\n"; } # All children have returned, get messages. foreach $pipe (@pipes) { while(defined($_ = $pipe->getline())) { # Do something ... } }

That is the bare bones of the mechanism. I have not attempted to reconcile use strict; and my or our here as it is just an illustration.

I hope this is useful.

Cheers,

JohnGG

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://541237]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others scrutinizing the Monastery: (5)
As of 2024-04-19 23:20 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found