Java Spring boot 使用SSH连接Mysql

文章展示了如何在JavaSpring应用中使用JSch库建立SSH连接,并通过SSH端口转发建立到远程MySQL数据库的连接。配置类包含了必要的参数如主机名、端口、用户名和密码,并提供了创建SSH会话和数据库连接的@Bean方法。
摘要由CSDN通过智能技术生成
  1. 导入JSch和MySQL驱动程序的依赖。
    <dependency>
        <groupId>com.jcraft</groupId>
        <artifactId>jsch</artifactId>
        <version>0.1.55</version>
    </dependency>
    
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>{your version}</version>
    </dependency>

  2. 创建SSH连接和MySQL连接的配置类。
    import com.jcraft.jsch.JSch;
    import com.jcraft.jsch.JSchException;
    import com.jcraft.jsch.Session;
    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    
    @Configuration
    public class MysqlSSHConfig {
        @Value("${ssh.host}")
        private String sshHost;
    
        @Value("${ssh.port}")
        private int sshPort;
    
        @Value("${ssh.user}")
        private String sshUser;
    
        @Value("${ssh.password}")
        private String sshPassword;
    
        @Value("${mysql.host}")
        private String mysqlHost;
    
        @Value("${mysql.port}")
        private int mysqlPort;
    
        @Value("${mysql.user}")
        private String mysqlUser;
    
        @Value("${mysql.password}")
        private String mysqlPassword;
    
        @Value("${mysql.database}")
        private String mysqlDatabase;
    
        @Bean
        public Session sshSession() throws JSchException {
            JSch jsch = new JSch();
            Session session = jsch.getSession(sshUser, sshHost, sshPort);
            session.setPassword(sshPassword);
            session.setConfig("StrictHostKeyChecking", "no");
            session.connect();
            return session;
        }
    
        @Bean
        public Connection mysqlConnection(Session session) throws SQLException {
            int localPort = 3307;
            session.setPortForwardingL(localPort, mysqlHost, mysqlPort);
            String url = "jdbc:mysql://localhost:" + localPort + "/" + mysqlDatabase + "?useSSL=false";
            Connection conn = DriverManager.getConnection(url, mysqlUser, mysqlPassword);
            return conn;
        }
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值