use IPC::Open2; use IPC::Open3; use strict; use IO::Select; my %ssh_handles; my @nodes = ('x','y','z'); my $val = "/test/*/26/*testingTESTING*"."\n"; my $command ='perl -e \"while(<>){chomp; \$val = \$_ ; \$res = \`ls -l /mnt/\*/\$val \`;}\"'; foreach my $node ( @nodes ) { my ( $wtr , $rdr , $err ) = ""; #my $pid = open3 ( $wtr , $rdr , $err , "ssh $node \$command" ); #my $pid = open2 ( $wtr , $rdr , "ssh $node \"$command\"" ); my $pid = open2 ( $wtr , $rdr , "ssh $node 'perl -e \"while(<>){chomp;\$val=\$_;\$res=\`ls -l /mnt/\*/\$val\`;}\"'" ); $ssh_handles{$node}{in} = $wtr if ( $wtr ); $ssh_handles{$node}{out} = $rdr if ( $rdr ); $ssh_handles{$node}{err} = $err if ( $err ); } foreach my $node ( sort keys ( %ssh_handles ) ) { print {$ssh_handles{$node}{in}} $val; close $ssh_handles{$node}{in}; my @ready; my $data = ""; my $select = IO::Select->new($ssh_handles{$node}{out}); if(@ready = $select->can_read(4.0)) { foreach my $rh (@ready) { my ($len,$buffer); if($len = sysread($rh, $buffer, 4000)) { if(!defined $len) { return undef; } $data .= $buffer; } } } print "[",$data,"]\n"; }