如何通过EC2 SSH隧道从本地Java程序连接到RDS [英] How to connect to RDS from local JAVA program via EC2 SSH tunnel

查看:46
本文介绍了如何通过EC2 SSH隧道从本地Java程序连接到RDS的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

出于调试目的,我正在尝试通过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。但您还应该能够使用数据库用户名和密码。

这篇关于如何通过EC2 SSH隧道从本地Java程序连接到RDS的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆