欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

使用jsch-spring-boot在本地访问远程云服务

程序员文章站 2024-03-26 13:24:29
...

现在很多创业公司都不再自建机房,更多地选择云主机,如阿里云腾讯云等。为了安全考虑,他们提供的关系数据库、nosql数据库等服务器都是不能直接访问的,只能通过云主机访问。

使用jsch-spring-boot在本地访问远程云服务

因为在本地不能访问,这样在开发和测试过程中就比较麻烦。

在Java环境中,可以使用JSch解决这个问题。本地程序通过JSch连接到云主机,通过端口转发访问云数据库等受限的服务器,相当于本地操作,很方便。

使用jsch-spring-boot在本地访问远程云服务

为方便使用JSch,参考Creating your own auto-configuration创建了一个spring boot自动配置项目jsch-spring-boot。

第1步:创建jsch-spring-boot自动配置项目。

如下图,一般两个子项目jsch-spring-boot-autoconfigurejsch-spring-boot-starterjsch-spring-boot-sample是测试子项目。

使用jsch-spring-boot在本地访问远程云服务

第2步:jsch-spring-boot自动配置实现。

一般只需要实现两个类,一个配置文件类,一个自动配置类。

@ConfigurationProperties(prefix = "spring.jsch")
public class JschProperties {
    /**
     * proxy host
     */
    private String proxyHost;
    /**
     * the port to access proxy host 
     */
    private int proxyPort;
    /**
     * the user login to the proxy host
     */
    private String proxyUser;
    /**
     * the user's password
     */
    private String proxyPassword;
    /**
     * default is no
     */
    private String strictHostKeyChecking = "no";
    /**
     * romte destination host
     */
    private String destHost;
    /**
     * romte destination port 
     */
    private int destPort;
    /**
     * local port 
     */
    private int localPort;
}

自动配置类代码。

@Configuration
@AutoConfigureOrder(Ordered.HIGHEST_PRECEDENCE)
@EnableConfigurationProperties(JschProperties.class)
public class JschAutoConfiguration implements InitializingBean, DisposableBean {

    private final JschProperties jschProperties;
    private Session session;

    public JschAutoConfiguration(JschProperties jschProperties) {
        this.jschProperties = jschProperties;
    }

    @Override
    public void afterPropertiesSet() throws Exception {
        JSch jsch = new JSch();
        session = jsch.getSession(jschProperties.getProxyUser(), jschProperties.getProxyHost(),
                jschProperties.getProxyPort());
        session.setPassword(jschProperties.getProxyPassword());
        session.setConfig("StrictHostKeyChecking", jschProperties.getStrictHostKeyChecking());
        System.out.println("Jsch_AutoConfiguration connect to:::host:" + jschProperties.getProxyHost() + ", port : "
                + jschProperties.getProxyPort() + ", user: " + jschProperties.getProxyUser());
        session.connect();
        System.out.println("Jsch_AutoConfiguration:::" + session.getServerVersion());// 打印SSH服务器版本信息
        int assinged_port = session.setPortForwardingL(jschProperties.getLocalPort(), jschProperties.getDestHost(),
                jschProperties.getDestPort());
        System.out.println("Jsch_AutoConfiguration:::localhost:" + assinged_port + " -> " + jschProperties.getDestHost()
                + ":" + jschProperties.getDestHost());
    }

    @Override
    public void destroy() throws Exception {
        if (session != null) {
            session.disconnect();
        }
        System.out.println("Jsch_AutoConfiguration::: destory connection");
    }
}
第3步:jsch-spring-boot配置

jsch-spring-boot-autoconfigure项目src/main/resources/META-INF创建spring.factories文件,配置自动配置类位置。

org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
jsch.autoconfigure.JschAutoConfiguration

jsch-spring-boot-starter项目src/main/resources/META-INF创建spring.provides文件,配置jsch spring boot自动配置项目名称,如下:

provides: jsch-spring-boot-autoconfigure
第4步:jsch-spring-boot引用
https://github.com/nivance/ssh2-spring-boot.git

因为没有将jsch-spring-boot放到任何maven公共仓库,所以需要将jsch-spring-boot的jar包安装到本地repository中。

cd ssh-spring-boot

mvn clean install

cd jsch-spring-boot/jsch-spring-boot-starter/target

mvn install:install-file -Dfile=jsch-spring-boot-starter-1.0.0.jar \
    -DgroupId=ssh2.spring.boot \
    -DartifactId=jsch-spring-boot-starter \
    -Dversion=1.0.0 \
    -Dpackaging=jar

cd ../../jsch-spring-boot-autoconfigure/target

mvn install:install-file -Dfile=jsch-spring-boot-autoconfigure-1.0.0.jar \
    -DgroupId=ssh2.spring.boot \
    -DartifactId=jsch-spring-boot-autoconfigure \ 
    -Dversion=1.0.0 \
    -Dpackaging=jar

然后就可以在其他项目中引用了。

<dependency>
    <groupId>ssh2.spring.boot</groupId>
    <artifactId>jsch-spring-boot-starter</artifactId>
    <version>1.0.0</version>
</dependency>
第5步:jsch-spring-boot使用

以访问远程mysql服务器为例,yml配置文件内容如下:

spring:
  ssh2:
    proxy-host: 101.99.35.198
    proxy-port: 2201
    proxy-user: java
    proxy-password: jdfkd199!
    dest-host: 101.99.35.199
    dest-port: 3306
    local-port: 3306
  datasource:
    url: jdbc:mysql://localhost:3306/evey?allowMultiQueries=true&useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull
    username: root
    password: 

具体代码可参考本项目jsch-spring-bootjsch-spring-boot-sample用例。