Hi,
This works for me on Win32, using Net::SSH2-0.18, built against an older version of libssh2, on perl-5.8:
use Net::SSH2;
use warnings;
use strict;
my $buflen = 10000;
my $buf1 = '0' x $buflen;
my $ssh2 = Net::SSH2->new();
$ssh2->connect('xxx.xxx.xxx.xxx') or die;
$ssh2->auth_password('xxx','xxxxxxx') or die "Unable to login $! \n";
my $chan = $ssh2->channel();
$chan->blocking(0);
$chan->shell();
for(1 .. 2) {
if($_ == 1) {$chan->write("echo \$PATH\n")}
else {$chan->write("echo \$HOME\n")}
select(undef,undef,undef,0.25);
$chan->read($buf1, $buflen);
print "BUF1: ", $buf1, "\n";
}
$chan->close;
However, running Net::SSH2-0.28, built against the latest libssh2-1.2.2, the buffer is *empty* in the first iteration - but filled correctly in subsequent iterations of the loop.
That is, with the older version of Net::SSH2 I'm getting:
BUF1: /usr/local/bin:/bin:/usr/bin:/usr/X11R6/bin:/usr/games:/home/rob
+/bin
BUF1: /home/rob
but with the latest, I'm getting:
BUF1:
BUF1: /home/rob
I can hack my way around the problem with the latest Net::SSH2 by changing the loop to:
for($i = 0, $i < 2, $i++) {
if($_ == 1) {$chan->write("echo \$PATH\n")}
else {$chan->write("echo \$HOME\n")}
select(undef,undef,undef,0.25);
$chan->read($buf1, $buflen);
if($buf1) {print "BUF1: ", $buf1, "\n"}
else {
print "Empty buffer ... trying again\n";
--$i;
}
}
That then produces (running the latest Net::SSH2):
Empty buffer ... trying again
BUF1: /usr/local/bin:/bin:/usr/bin:/usr/X11R6/bin:/usr/games:/home/rob
+/bin
BUF1: /home/rob
Hope there's something there that helps. (I don't have time to "tune" this script at the moment - or to look at the issue with the latest version.)
Cheers, Rob |