使用phpseclib从一个EC2实例到另一个EC2实例的连接

使用phpseclib从一个EC2实例到另一个EC2实例的连接,php,ssh,amazon-ec2,amazon,phpseclib,Php,Ssh,Amazon Ec2,Amazon,Phpseclib,嗨,我在一个EC2上使用HANA,并使用已经存在于SUSE Linux中的PHP从其他实例获取数据。当我尝试从本地系统获取数据时,同样的代码工作正常。但它在那里不起作用,也没有显示出任何错误。请帮忙。这是我的密码: error_reporting(1); set_time_limit(0); $date = date("d/m/Y-h:i:s") . "\n"; //to get today's date and time $logfile = "file-t

嗨,我在一个EC2上使用HANA,并使用已经存在于SUSE Linux中的PHP从其他实例获取数据。当我尝试从本地系统获取数据时,同样的代码工作正常。但它在那里不起作用,也没有显示出任何错误。请帮忙。这是我的密码:

error_reporting(1);
set_time_limit(0);
$date = date("d/m/Y-h:i:s") . "\n"; //to get today's date and time                  
$logfile = "file-transfer";
$fpath ="log/";
$filepath = $fpath .$logfile . '-log-' . date('Y-m-d') . '.csv';  //path of error log file
$fh1 = fopen($filepath, 'a'); //opening the error log file 
fwrite($fh1, "Process Started@" .$date. "\n");

include('Net/SFTP.php');
include('Crypt/RSA.php');

$key = new Crypt_RSA();

$key->loadKey(file_get_contents('key/private.ppk'));

$local_directory = 'sap/';

$remote_directory = '/var/www/';
$file = 'index.html';

$sftp = new Net_SFTP('ec2-XX-XXX-CCC-XX.ap-southeast-1.compute.amazonaws.com');
if (!$sftp->login('ubuntu', $key)) {    
    fwrite($fh1, "Login Failed" .$date. "\n");
}
else{

    fwrite($fh1, "Login Successful@" .$date. "\n");
}


 //$success = $sftp->put($remote_directory . $file,$local_directory . $file,NET_SFTP_LOCAL_FILE);
 $success = $sftp->get($remote_directory . $file,$local_directory . $file);
if($success){
     fwrite($fh1, "File Transferred Successfully@" .$date. "\n");
}
else{
    fwrite($fh1, "Error:" .$date.error_get_last(). "\n");

}

当我输入错误的主机名时,它会抛出登录失败消息。但是,当我输入正确的主机名时,它不起作用。

如果您在AWS内的网络中使用VPC,则需要打开安全组中的端口,以便同一安全组中的EC2实例可以看到并可以相互访问


谢谢迭戈,因为我一直在寻找解决方案,但没有找到任何积极的方面。我已检查出站默认为所有端口打开。入站我已指定22,与其他端口不同。请尝试将端口22授权给安全组。