java jdbc使用SSH隧道连接mysql数据库demo

 
  1.  
    package com.yws.echo_socket;
  2.  
     
  3.  
     
  4.  
    import com.jcraft.jsch.JSch;
  5.  
    import com.jcraft.jsch.Session;
  6.  
     
  7.  
    import java.sql.*;
  8.  
     
  9.  
    //http://my.oschina.net/Thinkeryjgfn/blog/177283
  10.  
    //http://www.cnblogs.com/I-will-be-different/p/3925351.html?utm_source=tuicool&utm_medium=referral
  11.  
    //java jdbc使用SSH隧道连接mysql数据库demo
  12.  
    public class ChangeDB {
  13.  
     
  14.  
     
  15.  
     
  16.  
    public static void go() {
  17.  
    try {
  18.  
    JSch jsch = new JSch();
  19.  
    Session session = jsch.getSession("yunshouhu", "192.168.0.102", 22);
  20.  
    session.setPassword("xxxx");
  21.  
    session.setConfig("StrictHostKeyChecking", "no");
  22.  
    session.connect();
  23.  
    System.out.println(session.getServerVersion());//这里打印SSH服务器版本信息
  24.  
     
  25.  
    //ssh -L 192.168.0.102:5555:192.168.0.101:3306 yunshouhu@192.168.0.102 正向代理
  26.  
    int assinged_port = session.setPortForwardingL("192.168.0.101",5555, "192.168.0.101", 3306);//端口映射 转发
  27.  
     
  28.  
    System.out.println("localhost:" + assinged_port);
  29.  
     
  30.  
    //ssh -R 192.168.0.102:5555:192.168.0.101:3306 yunshouhu@192.168.0.102
  31.  
    //session.setPortForwardingR("192.168.0.102",5555, "192.168.0.101", 3306);
  32.  
    // System.out.println("localhost: -> ");
  33.  
    } catch (Exception e) {
  34.  
    e.printStackTrace();
  35.  
    }
  36.  
    }
  37.  
     
  38.  
     
  39.  
     
  40.  
    public static void main(String[] args) {
  41.  
     
  42.  
     
  43.  
    try {
  44.  
    //1、加载驱动
  45.  
    Class.forName("com.mysql.jdbc.Driver");
  46.  
    } catch (ClassNotFoundException e) {
  47.  
    e.printStackTrace();
  48.  
    }
  49.  
    //2、创建连接
  50.  
    Connection conn = null;
  51.  
    Connection conn2 = null;
  52.  
    try {
  53.  
     
  54.  
    conn2 = DriverManager.getConnection("jdbc:mysql://localhost:3306/mysql", "hadoop", "xxxx");
  55.  
    getData(conn2);
  56.  
    } catch (SQLException e) {
  57.  
    System.out.println("未连接上数据库");
  58.  
    e.printStackTrace();
  59.  
    }
  60.  
     
  61.  
    try{
  62.  
    System.out.println("=============");
  63.  
    go();
  64.  
    conn = DriverManager.getConnection("jdbc:mysql://192.168.0.101:5555/mysql", "hadoop", "xxx");
  65.  
    getData(conn);
  66.  
     
  67.  
     
  68.  
    } catch (SQLException e) {
  69.  
    e.printStackTrace();
  70.  
    }
  71.  
     
  72.  
     
  73.  
     
  74.  
    }
  75.  
     
  76.  
    private static void getData(Connection conn) throws SQLException {
  77.  
     
  78.  
    // 获取所有表名
  79.  
    Statement statement = conn.createStatement();
  80.  
    ResultSet resultSet = statement
  81.  
    .executeQuery("select * from help_keyword");
  82.  
    // 获取列名
  83.  
    ResultSetMetaData metaData = resultSet.getMetaData();
  84.  
    for (int i = 0; i < metaData.getColumnCount(); i++) {
  85.  
    // resultSet数据下标从1开始
  86.  
    String columnName = metaData.getColumnName(i + 1);
  87.  
    int type = metaData.getColumnType(i + 1);
  88.  
    if (Types.INTEGER == type) {
  89.  
    // int
  90.  
    } else if (Types.VARCHAR == type) {
  91.  
    // String
  92.  
    }
  93.  
    System.out.print(columnName + "\t");
  94.  
    }
  95.  
    System.out.println();
  96.  
    // 获取数据
  97.  
    while (resultSet.next()) {
  98.  
    for (int i = 0; i < metaData.getColumnCount(); i++) {
  99.  
    // resultSet数据下标从1开始
  100.  
    System.out.print(resultSet.getString(i + 1) + "\t");
  101.  
    }
  102.  
    System.out.println();
  103.  
     
  104.  
    }
  105.  
    statement.close();
  106.  
    conn.close();
  107.  
    }
  108.  
     
  109.  
    }

  1.  
    <?xml version="1.0" encoding="UTF-8"?>
  2.  
    <project xmlns="http://maven.apache.org/POM/4.0.0"
  3.  
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4.  
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5.  
    <parent>
  6.  
    <artifactId>grpc-demo</artifactId>
  7.  
    <groupId>org.jiepu</groupId>
  8.  
    <version>1.0</version>
  9.  
    </parent>
  10.  
    <modelVersion>4.0.0</modelVersion>
  11.  
     
  12.  
    <artifactId>echo_socket</artifactId>
  13.  
     
  14.  
    <properties>
  15.  
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  16.  
    <java.version>1.6</java.version>
  17.  
    </properties>
  18.  
     
  19.  
    <dependencies>
  20.  
     
  21.  
    <dependency>
  22.  
    <groupId>com.jcraft</groupId>
  23.  
    <artifactId>jsch</artifactId>
  24.  
    <version>0.1.53</version>
  25.  
    </dependency>
  26.  
    <dependency>
  27.  
    <groupId>mysql</groupId>
  28.  
    <artifactId>mysql-connector-java</artifactId>
  29.  
    <version>5.1.36</version>
  30.  
    </dependency>
  31.  
    </dependencies>
  32.  
    <build>
  33.  
    <plugins>
  34.  
    <plugin>
  35.  
    <groupId>org.apache.maven.plugins</groupId>
  36.  
    <artifactId>maven-compiler-plugin</artifactId>
  37.  
    <configuration>
  38.  
    <source>${java.version}</source>
  39.  
    <target>${java.version}</target>
  40.  
    </configuration>
  41.  
    </plugin>
  42.  
     
  43.  
    <plugin>
  44.  
    <groupId>org.apache.maven.plugins</groupId>
  45.  
    <artifactId>maven-shade-plugin</artifactId>
  46.  
    <executions>
  47.  
    <execution>
  48.  
    <phase>package</phase>
  49.  
    <goals>
  50.  
    <goal>shade</goal>
  51.  
    </goals>
  52.  
    <configuration>
  53.  
    <transformers>
  54.  
    <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
  55.  
    <mainClass>com.yws.echo_socket.ChangeDB</mainClass>
  56.  
    </transformer>
  57.  
    </transformers>
  58.  
    </configuration>
  59.  
    </execution>
  60.  
    </executions>
  61.  
    </plugin>
  62.  
    </plugins>
  63.  
    </build>
  64.  
    </project>

java jdbc使用SSH隧道连接mysql数据库demo的更多相关文章

  1. Navicat 或者Java的JDBC通过SSH Tunnel连接MySQL数据库

    JDBC通过SSH Tunnel连接MySQL数据库 - 明明 - CSDN博客https://blog.csdn.net/a351945755/article/details/21782693 Na ...

  2. springboot通过ssh通道连接mysql数据库

    navicat可以通过ssh通道连接mysql数据库,那java中如何实现了,springboot又该怎样集成呢? 1.添加包 <dependency> <groupId>co ...

  3. SQLyog通过ssh隧道连接MySQL

    1.简介 因为现在很多公司服务的数据库为了安全起见,都不允许直接连接其服务,而只能通过跳板机进行登陆到数据库.而ssh有一项非常有用的功能,即端口转发的隧道功能,让一些不安全的服务,像TCP.POP3 ...

  4. kettle通过SSH连接Mysql数据库(SSH隧道)

    kettle通过SSH连接Mysql数据库(SSH隧道) Kettle无法直接连接使用SSH通道的MySQL,通过SSH隧道(推荐)或者需要借助工具PuTTY(不用时需要注销不推荐),具体操作如下所示 ...

  5. JAVA-数据库之JDBC连接MySQL数据库

    相关资料:<21天学通Java Web开发> JDBC连接MySQL数据库1.如果需要通过JDBC来连接MySQL数据库,还必须先在MySQL数据库服务器中创建数据库和表. Connect ...

  6. jmeter连接Mysql数据库测试性能初探

    Jmeter mysql性能测试演示 1.  Jmeter是java开发的,jmeter连接mysql数据库当然需要jdbc驱动,这个可以在网上下载mysql-connector-java包,然后解压 ...

  7. java 通过jdbc连接MySQL数据库

    先了解下JDBC的常用接口 1.驱动程序接口Driver 每种数据库的驱动程序都应该提供一个实现java.sql.Driver接口的类,简称Driver类.通常情况下,通过java.lang.Clas ...

  8. java jdbc 连接mysql数据库 实现增删改查

    好久没有写博文了,写个简单的东西热热身,分享给大家. jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打 ...

  9. Java使用JDBC连接MySQL数据库

    1.引用 JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写 ...

随机推荐

  1. discuz网站前端代码优化思路

    一.head标签中的局部 1.URL设计 URL尽量含有通用已成趋向的移动命名,例如“m./wap./3g./mobi./mobile./mob/wml/”,能够在子域名等方面表现 2.页面顶部的do ...

  2. Btn 样式

    .btn { display: inline-block; padding: 6px 12px; margin-bottom: 0; font-size: 14px; font-weight: nor ...

  3. SDOI2012 走迷宫

    走迷宫 Morenan被困在了一个迷宫里.迷宫可以视为N个点M条边的有向图,其中Morenan处于起点S,迷宫的终点设为T.可惜的是,Morenan非常的脑小,他只会从一个点出发随机沿着一条从该点出发 ...

  4. 注解 @EnableFeignClients 工作原理

    概述在Spring cloud应用中,当我们要使用feign客户端时,一般要做以下三件事情 : 使用注解@EnableFeignClients启用feign客户端:示例 : @SpringBootAp ...

  5. ava js 测试框架基本试用

    随着js 越来越强大,日常使用中关于js 的问题也就越突出了,我们需要关注的点也就不能只像以前那样 只编写简单的功能实现,我们同时也需要关注js 的健壮性,测试就是其中一个比较重要的环节,以下 是av ...

  6. chart.xkcd 可绘制粗略,开通,手绘样式的图表库

    chart.xkcd 可以用来绘制手绘样式的图表,使用简单,样式也挺好看 简单使用 代码 index.html <!DOCTYPE html> <html lang="en ...

  7. mpvue图片上传

    mpvue小程序项目中的图片上传 我的csdn博客地址:https://blog.csdn.net/zmkyf1993 一般我是优先更新csdn内容,然后在拷过来的. 效果图 通过mpvue文档得知他 ...

  8. MySQL中自增ID起始值修改方法

    在实际测试工作过程中,有时因为生产环境已有历史数据原因,需要测试环境数据id从某个值开始递增,此时,我们需要修改数据库中自增ID起始值,下面以MySQL为例: 表名:users; 建表时添加: ); ...

  9. spring(一)IOC & AOP

    参考文档: spring详解:http://www.cnblogs.com/ysocean/p/7466191.html(可以说非常详细了) aop源码详解:https://www.cnblogs.c ...

  10. 服务器负载过高问题分析-不是cpu高负载也不是IO负载如何处理(阿里 几乎是必考题)

    关于top命令 经常问load average 参考:load average 定义(网易面试) jvm dump的使用 参考:Jvm dump jstack jmap jstat 介绍与使用(内存与 ...