Parent process unable to read messages from child process



Hello,

I've a process which is supposed to do the following:
1.A Parent process has to fork to create fixed number of child
processes. (This fixed number changes each time my code runs.)
2. Each child computes certain values and writes these values on to a
pipe.
3. The parent should read each of these values from pipe output of all
children and store them in a global variable to be used later in the
process.

Fork work correct, Child processes compute the correct value, however
Parent is unable to read output of all children. For e.g. when 3
children are created, one child completes execution first, and parent
is able to read it's value. The other two processes complete 20
seconds later and exit immediately one after the other. The parent is
unable to read the values of the 2nd and 3rd child.

I want the parent to be able to read the values of all the children
immediately after they exit.
Can some one help me fix the problem?

Here is my script:

use IO::Select;
use IO::File;

my $selectpipe = new IO::Select;

for ($splitnum = 1; $splitnum <= $numparts; $splitnum++) { #$numparts
changes each time.
pipe($uncompread, $uncompwrite) or die "Cannot pipe: $!";
my $pid = fork();
die "fork: $!" unless defined $pid;
if ($pid){#parent
push (@childs, $pid);
close $uncompwrite;
$selectpipe->add($uncompread);
} else { #child
close $uncompread;
$uncompwrite->autoflush(1);

# compute the following arrays:
# $uncompfile[$splitnum],
# $uncompsize[$splitnum],
# $uncompcksum[$splitnum]
# and store the above values in the array: $uncomp[$splitnum
- 1] as follows:

$uncomp[$splitnum - 1] = "$uncompfile[$splitnum]
$uncompsize[$splitnum] $uncompcksum[$splitnum]";
print $uncompwrite $uncomp[$splitnum - 1];

exit;
}
}

# In the following part I'm trying to store the @uncomp() array above
in the @filedetail() array.
# The number of elements in @filedetail() array should be equal to
$numparts above.
# This is the part which causes error. I'm unable to read all elements
in the @uncomp() array
# above. After the first element in the @uncomp() array is read, the
process exits. Can
# somebody please help?

$count = 0;
while(1){
foreach my $client ($selectpipe->can_read) {
$filedetail[$count] = <$uncompclient>;
$count++;
}
}
close $uncompread;
close $uncompwrite;

foreach(@childs){
waitpid($_,0);
}

I'm using Perl version 5.8.5 on OS-Red Hat Linux.

-Thanks,
Regards,
Gauri

.



Relevant Pages

  • Re: Convert array of values into jTree
    ... The think about the ORDER the Jtree has to be created. ... the parent and the information for the child. ... of parents scattered all over the array - it's not sorted ...
    (comp.lang.java.programmer)
  • Parent process unable to read messages from child process
    ... 1.A Parent process has to fork to create fixed number of child ... The parent should read each of these values from pipe output of all ... # and store the above values in the array: ... in the @uncomp() array ...
    (comp.lang.perl.misc)
  • Re: Convert array of values into jTree
    ... The think about the ORDER the Jtree has to be created. ... the parent and the information for the child. ... of parents scattered all over the array - it's not sorted ...
    (comp.lang.java.programmer)
  • Re: csv, array or alternative in mysql table?
    ... > insert multiple and seperate strings (like an array or a csv file) ... create table parent ( ... The idea is that the common column "somekey" links values from the child to ...
    (comp.lang.php)
  • Unix Programming FAQ (v1.37)
    ... Why use _exit rather than exit in the child branch of a fork? ... Why doesn't my process get SIGHUP when its parent dies? ... How do I create a named pipe? ... How do I compare strings using regular expressions? ...
    (comp.unix.programmer)