SSH代理连接JDBC数据库

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: SSH代理连接JDBC数据库

依赖配置pom

<dependency>
    <groupId>com.jcraft</groupId>
    <artifactId>jsch</artifactId>
    <version>0.1.54</version>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.38</version>
</dependency>

创建代理会话

/**
 * 创建代理会话。会话使用结束后,别忘了调用closeSession以关闭会话。
 */
public static Session getSession(String sshIp, 
        String sshUser, 
        int sshPort, 
        String sshPwd, 
        String sshKeyPath) throws JSchException {
    JSch jSch = new JSch();
    if(sshKeyPath != null) jSch.addIdentity(sshKeyPath);
    Session sesion = jSch.getSession(sshUser, sshIp, sshPort);
    sesion.setPassword((sshPwd == null) ? "" : sshPwd);
    Properties config = new Properties();
    config.put("StrictHostKeyChecking", "no");
    sesion.setConfig(config);
    sesion.connect();
    return sesion;
}

创建本地代理端口

/**
 * 创建本地代理端口。
 */
public static int getPortForwardingL(Session sesion, 
        int loaclPort, 
        String mysqlIp, 
        int mysqlPort) throws JSchException {
    return sesion.setPortForwardingL(loaclPort, mysqlIp, mysqlPort);
}

创建数据库连接

/**
 * 创建数据库连接。
 */
public static Connection getConnection(String driver, 
        String localIp, 
        int portForwardingL, 
        String db, 
        String user, 
        String pwd) throws Exception {
    String mysqlUrl = "jdbc:mysql://" + localIp + ":" + portForwardingL + "/" + db + "?characterEncoding=utf8&useSSL=false"; 
    Class.forName(driver); 
    return DriverManager.getConnection(mysqlUrl, user, pwd);
}

调用示例代码

public static void main(String[] args) throws Exception {
    // 代理服务器信息
    String sshIp = "xxx.xxx.xxx.xxx";
    String sshUser = "user";
    int sshPort = 8585;
    String sshPwd = "";
    String sshKeyPath = "本地路径/id_rsa.rsa";
    
    // 本机基本设置
    int localPort = 12365; 
    String localIp = "localhost";
    
    // 数据库JDBC连接信息
    String mysqlIp = "xxx.xxx.xxx.xxx"; 
    int mysqlPort = 3306;
    String mysqlDriver = "com.mysql.jdbc.Driver";
    String mysqlUser = "user";
    String mysqlPwd = "pwd";
    String mysqlDB = "db";
    
    // 创建代理会话。会话使用结束后,别忘了调用closeSession以关闭会话。
    Session session = SsshJdbcUtils.getSession(sshIp, sshUser, sshPort, sshPwd, sshKeyPath);
    
    // 创建本地代理端口。
    int portForwardingL = SsshJdbcUtils.getPortForwardingL(session, localPort, mysqlIp, mysqlPort);
    
    // 创建数据库连接。
    Connection connection = SsshJdbcUtils.getConnection(mysqlDriver, localIp, portForwardingL, mysqlDB, mysqlUser, mysqlPwd);
    
    // 查询数据
    Statement statement = connection.createStatement();
    ResultSet resultSet = statement.executeQuery("show tables");
    if(resultSet != null) {
        while(resultSet.next()) {
            String tableName = resultSet.getString(1);
            System.err.println(tableName);
        }
    }
    
    // 关闭相关连接
    if(resultSet != null && !resultSet.isClosed()) resultSet.close();
    if(statement != null && !statement.isClosed()) statement.close();
    if(connection != null && !connection.isClosed()) connection.close();
    if(session != null && session.isConnected()) session.disconnect();
}
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
6天前
|
网络安全 开发工具 git
配置本地环境以管理Git多账户SSH连接的方法
通过以上步駟设置后, 您可以轻松管理多個 Git 账户并且根据不同项目需求切换 SSH 密匙进行版本控制操作。
105 20
|
18天前
|
SQL Java 关系型数据库
Java连接MySQL数据库环境设置指南
请注意,在实际部署时应该避免将敏感信息(如用户名和密码)硬编码在源码文件里面;应该使用配置文件或者环境变量等更为安全可靠地方式管理这些信息。此外,在处理大量数据时考虑使用PreparedStatement而不是Statement可以提高性能并防止SQL注入攻击;同时也要注意正确处理异常情况,并且确保所有打开过得资源都被正确关闭释放掉以防止内存泄漏等问题发生。
61 13
|
20天前
|
SQL 关系型数据库 MySQL
MySQL数据库连接过多(Too many connections)错误处理策略
综上所述,“Too many connections”错误处理策略涉及从具体参数配置到代码层面再到系统与架构设计全方位考量与改进。每项措施都需根据具体环境进行定制化调整,并且在执行任何变更前建议先行测试评估可能带来影响。
341 11
|
16天前
|
Unix Linux Shell
指定端口-SSH连接的目标(告别 22 端口暴力破解)
本文介绍了 SSH 命令 `ssh -p 44907 root@IP` 的含义与使用方法,包括命令结构拆解、完整示例及执行过程详解,帮助用户安全地远程登录服务器。
89 0
|
6月前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
|
5月前
|
安全 Linux 网络安全
YashanDB数据库服务端SSL连接配置
YashanDB支持通过SSL连接确保数据传输安全,需在服务端生成根证书、服务器证书及DH文件,并将根证书提供给客户端以完成身份验证。服务端配置包括使用OpenSSL工具生成证书、设置SSL参数并重启数据库;客户端则需下载根证书并正确配置环境变量与`yasc_env.ini`文件。注意:启用SSL后,所有客户端必须持有根证书才能连接,且SSL与密码认证独立运行。
|
6月前
|
Java 数据库连接 数据库
【YashanDB知识库】WAS配置YashanDB JDBC连接
【YashanDB知识库】WAS配置YashanDB JDBC连接
|
1月前
|
网络安全 数据安全/隐私保护 开发者
诊断并修复SSH连接Github时遇到的"connection closed"错误。
解决"connection closed"错误往往是一个排除法的过程。需要从基础的网络检查做起,逐步过渡到深入的配置和服务端日志审查。每一步都应当仔细验证,确保不遗漏可能导致连接问题的任何细节。在执行以上步骤后,大多数SSH连接问题可以得到解决。如果所有步骤都未能解决问题,可能需要寻求更专业的技术支持,或者在GitHub社区寻找是否有其他开发者遇到并解决了类似的问题。
281 0

热门文章

最新文章