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

时间:2014-04-10 05:27:51

标签: 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-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");

}

错误地,当我输入错误的主机名时,它会抛出登录失败的消息。但是当我输入正确的主机名时,它无效。

1 个答案:

答案 0 :(得分:2)

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

http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_SecurityGroups.html