如何通过EC2 SSH隧道从本地Java程序连接到RDS

2022-07-02 00:00:00 ssh mysql amazon-rds java jsch

出于调试目的,我正在尝试通过SSH隧道从本地Java程序连接到EC2实例的RDS数据库。我正在尝试建立到EC2实例的SSH隧道,然后将端口转发到RDS数据库。以下是我的代码。

final int localPort = 9999;
// Create BaiscDataSource.
final String databaseURL = "jdbc:mysql://localhost:" + localPort + "/database";
// SSH Tunnel.
final JSch jsch = new JSch();
jsch.addIdentity(sshKeyPath);
this.session = jsch.getSession(ec2Username, ec2Host, 22);
this.session.setTimeout(0);
this.session.setConfig("StrictHostKeyChecking", "no");
this.session.connect();
this.session.setPortForwardingL(localPort, rdsHost, 3306);

请帮帮忙!

编辑者:rouply_dev于2012年10月2日下午4:17


解决方案

我使用堡垒主机并使用本地端口转发。

ssh -i ec2key.pem -N -L 3306:my-dev-db.cluster-cdnxxxxxxxxxx.ap-southeast-1.rds.amazonaws.com:3306 ec2-user@54.253.196.193

54.253.196.193是Bastian主机的IP。

最后,我使用AWS Secrets Manager连接到本地主机:3306。但您还应该能够使用数据库用户名和密码。

相关文章