当前位置: 首页 > news >正文

使用隧道(Tunnel)连接PostgreSQL数据库(解决防火墙问题)

目录

■前言

■遇到的问题

■为什么尝试 Java代码实现

■Java代码可以成功

POM

PostgreSQ驱动

Java

需要的参数信息

■PostgreSQL的数据库中,默认的Schema (public)


==========

■前言

・使用PostgreSQL数据库,远程连接时因为防火墙问题无法直接访问

・通过PostgreSQL的pgAdmin工具,连接时使用隧道(Tunnel トンネル),即可正常访问

・隧道:找一台通过了防火墙的服务器,作为隧道,隧道配置中,填写这台服务器的账号密码 (相当于代理服务器)

===

■遇到的问题

・但是我们在连接时,如果使用A5M2,版本过低(据说要2.20.X才行),使用2.19.X之下版本,都会报下面的错误

・no pg_hba.conf entry for host "10.92.95.19", user "postgres", database "XXXXXXXX", no encryption

(上面的IP是作为隧道的服务器的IP)

===A5下载

m.matsubara A5:SQL Mk-2 - SQL Development tool/ER Diagram tool

===上面地址来源:GitHub

https://github.com/m-matsubara

===

■为什么尝试 Java代码实现

・pgAdmin是 安装 PostgreSQL后再带的工具,安装 PostgreSQL 需要申请才能安装。(我们可以通过java代码直接实现访问)

■Java代码可以成功

POM

===

<dependencies><dependency><groupId>org.postgresql</groupId><artifactId>postgresql</artifactId><version>42.7.7</version></dependency><dependency><groupId>com.jcraft</groupId><artifactId>jsch</artifactId><version>0.1.55</version></dependency>
</dependencies>

PostgreSQ驱动

https://github.com/pgjdbc/pgjdbc/tags

===

Java

import com.jcraft.jsch.JSch;
import com.jcraft.jsch.Session;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.Properties;public class PostgreSQLTunnelConnection {// 配置参数 - 请根据实际情况修改private static final String SSH_USER = "your_ssh_username";private static final String SSH_PASSWORD = "your_ssh_password";private static final String SSH_HOST = "ssh.server.com";private static final int SSH_PORT = 22;private static final String DB_HOST = "localhost"; // 通过SSH隧道后数据库主机private static final int DB_PORT = 5432;private static final String DB_NAME = "your_database";private static final String DB_USER = "your_db_username";private static final String DB_PASSWORD = "your_db_password";private static Session session;private static Connection connection;private static int localPort = 5433; // 本地转发端口public static void main(String[] args) {try {// 加载PostgreSQL JDBC驱动Class.forName("org.postgresql.Driver");// 建立SSH隧道System.out.println("正在建立SSH隧道...");createSSHTunnel();// 连接数据库System.out.println("正在连接数据库...");connectToDatabase();// 执行查询System.out.println("执行查询...");executeQuery();// 关闭连接System.out.println("关闭连接...");closeConnections();} catch (Exception e) {System.err.println("发生错误: " + e.getMessage());e.printStackTrace();}}private static void createSSHTunnel() throws Exception {JSch jsch = new JSch();session = jsch.getSession(SSH_USER, SSH_HOST, SSH_PORT);session.setPassword(SSH_PASSWORD);Properties config = new Properties();config.put("StrictHostKeyChecking", "no");session.setConfig(config);session.connect();System.out.println("SSH连接已建立");// 设置端口转发session.setPortForwardingL(localPort, DB_HOST, DB_PORT);System.out.println("SSH隧道已建立,本地端口: " + localPort);}private static void connectToDatabase() throws Exception {String dbUrl = "jdbc:postgresql://localhost:" + localPort + "/" + DB_NAME;connection = DriverManager.getConnection(dbUrl, DB_USER, DB_PASSWORD);System.out.println("数据库连接成功!");}private static void executeQuery() throws Exception {// 直接查询information_schema.tables表,按schema和表名分组String query = "SELECT table_schema, table_name " +"FROM information_schema.tables " +"WHERE table_schema NOT LIKE 'pg_%' " +"AND table_schema != 'information_schema' " +"ORDER BY table_schema, table_name";Statement stmt = connection.createStatement();ResultSet rs = stmt.executeQuery(query);System.out.println("数据库中的所有Schema及其包含的表:");String currentSchema = null;while (rs.next()) {String schemaName = rs.getString("table_schema");String tableName = rs.getString("table_name");// 当遇到新的Schema时,输出Schema名称if (!schemaName.equals(currentSchema)) {if (currentSchema != null) {System.out.println(); // 在Schema之间添加空行}System.out.println("Schema: " + schemaName);currentSchema = schemaName;}// 输出表名System.out.println("  - " + tableName);}rs.close();stmt.close();}rs.close();stmt.close();}private static void closeConnections() {try {if (connection != null && !connection.isClosed()) {connection.close();System.out.println("数据库连接已关闭");}} catch (Exception e) {System.err.println("关闭数据库连接时出错: " + e.getMessage());}if (session != null && session.isConnected()) {session.disconnect();System.out.println("SSH连接已关闭");}}
}

需要的参数信息

・SSH_USER: SSH用户名
・SSH_PASSWORD: SSH密码
・SSH_HOST: SSH服务器地址
・DB_NAME: 数据库名称
・DB_USER: 数据库用户名
・DB_PASSWORD: 数据库密码

■PostgreSQL的数据库中,默认的Schema (public)

默认的Schema是public

====

http://www.dtcms.com/a/344595.html

相关文章:

  • CentOS 10安装Ollama
  • Redis高级篇 | 分布式缓存四大核心问题讲解:持久化、主从集群、哨兵与分片集群
  • 【Java后端】【可直接落地的 Redis 分布式锁实现】
  • Python数据治理实战从爬虫到情感分析的电商评论处理系统
  • MySQL 高级主题:索引优化、ORM 与数据库迁移
  • java8 findAny()、findFirst()空指针NullPointerException问题
  • [RestGPT] RestGPT智能体
  • 从零开始的云计算生活——第四十九天,长路漫漫,kubernetes模块之持久化存储
  • 计算机网络技术-第七章
  • 嵌入式学习 day57 驱动-驱动框架
  • 利用 PHP 爬虫获取淘宝商品描述实战指南
  • 全志T113学习记录
  • 渲染新纪元:人工智能如何重构数字内容生产流水线
  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘uvicorn’问题
  • EMNLP 2025数据公布,投稿量首次突破8000
  • 【AGI使用教程】GPT-OSS 本地部署(1)
  • Java StringBuilder 深度解析
  • c++的可扩展性方法
  • 20250822:从梦中云南到现实调试:海康球机 API 小故障排查
  • 以下是基于图论的归一化切割(Normalized Cut)图像分割工具的完整实现,结合Tkinter界面设计及Python代码示
  • 【数据结构C语言】顺序表
  • ZYNQ启动流程——ZYNQ学习笔记11
  • 线性回归学习
  • 消费盲返模式:重构快消行业营销生态的破局之道与风险防控指南
  • 无服务器函数:扩展 Next.js 应用的功能
  • 四十三、【完结篇】消息通知:集成多渠道机器人与邮件通知
  • Android 关于activity-ktx的 by viewModels()踩坑记录与分析
  • 龙蜥Confidential MaaS解决方案如何破解MaaS “黑盒”困局|《AI 进化论》第三期
  • MATLAB:编程入门、多维可视化、时间序列/图像/地图/遥感/点云数据处理及生态模型构建
  • 软件设计师——计算机网络学习笔记