首页 >数据库 >mysql教程 >如何在 Java 中通过 SSH 隧道连接到远程 MySQL 数据库?

如何在 Java 中通过 SSH 隧道连接到远程 MySQL 数据库?

Patricia Arquette
Patricia Arquette原创
2024-11-29 10:28:11759浏览

How to Connect to a Remote MySQL Database via SSH Tunneling in Java?

在 Java 中通过 SSH 建立远程 MySQL 连接

可以实现从 Java 应用程序通过 SSH 与远程 MySQL 数据库建立连接通过利用 SSH 隧道和 JDBC 的组合。具体操作方法如下:

SSH 隧道

  1. 在本地计算机上,设置 SSH 隧道以将计算机上的端口 1234 转发到端口 3306在远程 MySQL 服务器上。要使用 SSH 的命令行客户端执行此操作,请运行: ssh -L 1234:localhost:3306 mysql.server.remote
  2. 使用 Java 的 JSch 库创建将端口 1234 转发到远程服务器的 SSH 会话。

JDBC连接

SSH 隧道建立后,您可以使用 JDBC 连接 MySQL 数据库:

  1. 创建 java.sql.Connection 对象,指定 JDBC URL作为 jdbc:mysql://localhost:1234/[database].
  2. 使用您的 MySQL 凭据进行身份验证并继续使用您的数据库

代码示例

这是一个演示连接的基本代码示例:

import com.jcraft.jsch.*;
import java.sql.*;

public class ConnectToRemoteMySQLThroughSSH {

   public static void main(String[] args) throws JSchException, SQLException {
      // SSH Session Setup
      JSch jsch = new JSch();
      Session session = jsch.getSession("username", "host", 22);
      session.setConfig("StrictHostKeyChecking", "no");
      session.setPassword("password");
      session.connect();

      // Port Forwarding
      session.setPortForwardingL(1234, "localhost", 3306);

      // JDBC Connection
      Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:1234/[database]", "root", "password");

      // Database Operations...

      connection.close();
      session.disconnect();
   }
}

以上是如何在 Java 中通过 SSH 隧道连接到远程 MySQL 数据库?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn