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

SpringBoot利用SSH隧道安全访问内网MySQL数据库实战

1. 为什么需要SSH隧道连接MySQL在企业开发中我们经常遇到这样的场景数据库服务器部署在内网环境开发机在外网无法直接访问。比如测试环境的MySQL部署在192.168.1.100而你的SpringBoot应用运行在办公网络192.168.2.x网段。传统做法可能是让运维开通防火墙端口映射但这会带来安全隐患。我去年参与的一个金融项目就遇到这种情况。客户的生产数据库完全隔离在内网但开发阶段需要频繁执行SQL调试。最终我们采用SSH隧道方案既满足了安全要求又实现了开发便利性。这种方案的核心优势在于加密传输所有数据经过SSH加密通道传输避免明文暴露权限控制通过SSH密钥或账号密码实现访问控制零网络改造不需要调整现有网络架构临时性连接断开后隧道自动销毁不留安全隐患2. 环境准备与依赖配置2.1 必备组件清单在开始编码前请确保准备好以下要素一台具有SSH访问权限的跳板机通常由运维提供目标MySQL数据库的内网地址和端口有效的SSH认证凭据密码或密钥文件SpringBoot 2.x项目基础环境2.2 Maven依赖配置核心依赖是JSch库它是Java实现SSH协议的经典工具。在pom.xml中添加dependency groupIdcom.jcraft/groupId artifactIdjsch/artifactId version0.1.55/version !-- 建议使用最新版 -- /dependency同时确保有MySQL驱动依赖dependency groupIdmysql/groupId artifactIdmysql-connector-java/artifactId scoperuntime/scope /dependency3. 实现SSH隧道连接3.1 基础版工具类实现先看一个最简实现方案。创建SSHManager类import com.jcraft.jsch.*; public class SSHTunnel { private Session session; private static final int LOCAL_PORT 3307; // 本地映射端口 public void connect(String sshHost, int sshPort, String sshUser, String sshPassword, String mysqlHost, int mysqlPort) throws JSchException { JSch jsch new JSch(); session jsch.getSession(sshUser, sshHost, sshPort); session.setPassword(sshPassword); Properties config new Properties(); config.put(StrictHostKeyChecking, no); // 首次连接免验证 session.setConfig(config); session.connect(); // 关键步骤端口转发 session.setPortForwardingL(LOCAL_PORT, mysqlHost, mysqlPort); } public void disconnect() { if(session ! null session.isConnected()) { session.disconnect(); } } }使用时需要注意StrictHostKeyChecking设为no仅限测试环境生产环境应配置known_hosts本地端口建议选择3306-3399范围避免冲突连接超时时间可通过session.setTimeout(5000)设置3.2 SpringBoot优雅集成方案更推荐使用SpringBoot的配置化方式。首先创建配置类Configuration ConditionalOnProperty(name ssh.tunnel.enabled, havingValue true) public class SshTunnelConfig { Value(${ssh.host}) private String sshHost; Value(${ssh.port:22}) private int sshPort; // 其他参数... Bean(destroyMethod disconnect) public SSHTunnel sshTunnel() throws JSchException { SSHTunnel tunnel new SSHTunnel(); tunnel.connect(sshHost, sshPort, ...); return tunnel; } }然后在application.yml中配置ssh: tunnel: enabled: true host: jump.server.com username: dev_user password: ${SSH_PASSWORD} # 建议从环境变量读取 forward: local-port: 3307 remote-host: mysql.internal remote-port: 33064. 数据库连接配置技巧4.1 动态数据源配置隧道建立后数据源URL需要指向本地映射端口spring.datasource.urljdbc:mysql://127.0.0.1:3307/order_db?useSSLfalse spring.datasource.usernamedb_user spring.datasource.password${DB_PASSWORD}4.2 连接池参数优化由于经过隧道转发网络延迟会增大建议调整连接池参数spring: datasource: hikari: maximum-pool-size: 10 # 默认值可能过高 connection-timeout: 30000 idle-timeout: 6000005. 生产环境实战经验5.1 密钥认证最佳实践密码认证不安全推荐使用SSH密钥// 在connect方法中添加 jsch.addIdentity(/path/to/private_key, key_passphrase); // 移除session.setPassword()服务器端需要将公钥添加到~/.ssh/authorized_keys设置合适的文件权限chmod 600 ~/.ssh/authorized_keys5.2 稳定性保障方案我遇到过隧道意外断开导致服务不可用的情况推荐以下解决方案心跳检测定时执行简单SQL保持连接Scheduled(fixedRate 300000) public void keepAlive() { jdbcTemplate.execute(SELECT 1); }自动重连捕获异常时重建连接Retryable(maxAttempts 3, backoff Backoff(delay 1000)) public void connectWithRetry() throws JSchException { // 连接代码 }连接池分离为关键业务配置独立数据源6. 常见问题排查指南6.1 连接超时问题错误现象java.net.ConnectException: Connection timed out排查步骤先用SSH客户端测试基础连接性ssh -v -p 22 userjump.server检查防火墙规则验证跳板机的端口转发权限6.2 认证失败处理错误信息Auth fail解决方案检查用户名/密码是否正确确认服务器是否允许密码认证# 在服务器上检查 grep PasswordAuthentication /etc/ssh/sshd_config密钥认证需要检查私钥格式是否为PEM6.3 端口冲突问题错误信息java.net.BindException: Address already in use处理方法查看占用端口的进程lsof -i :3307修改local-port配置为其他值确保没有重复创建隧道7. 安全增强建议7.1 敏感信息保护千万不要将密码硬编码在代码中推荐做法使用环境变量String password System.getenv(SSH_PASSWORD);配合配置中心如Spring Cloud Config密钥文件存放在安全目录设置400权限7.2 网络层加固限制跳板机的SSH访问IP为数据库用户设置最小权限启用MySQL SSL连接定期轮换SSH密钥8. 替代方案对比当SSH隧道不能满足需求时可以考虑方案优点缺点VPN全局网络互通配置复杂权限控制粗粒度数据库中间件功能丰富需要额外维护组件云厂商专线稳定低延迟成本较高在最近的一个物联网项目中我们最终选择了SSH隧道白名单的组合方案。既满足了安全审计要求又保证了开发调试效率。实际使用中要注意及时关闭不再需要的隧道连接避免资源浪费。

相关文章:

SpringBoot利用SSH隧道安全访问内网MySQL数据库实战

1. 为什么需要SSH隧道连接MySQL? 在企业开发中,我们经常遇到这样的场景:数据库服务器部署在内网环境,开发机在外网无法直接访问。比如测试环境的MySQL部署在192.168.1.100,而你的SpringBoot应用运行在办公网络192.168.…...

华为eNSP实战:5分钟搞定VRF多租户网络隔离(附完整配置命令)

华为eNSP实战:5分钟构建企业级VRF多租户隔离网络 当企业网络需要同时承载生产系统、办公环境和测试平台时,如何确保各业务流量完全隔离?传统VLAN划分已无法满足复杂场景需求。华为eNSP模拟器配合VRF技术,能在单台设备上创建多个逻…...

高效数据迁移:利用kettle实现CSV与Excel文件快速导入数据库

1. 为什么选择Kettle处理数据迁移? 最近接手了一个数据迁移项目,需要把几十万条CSV和Excel格式的销售记录导入到MySQL数据库。刚开始尝试用Python脚本处理,结果发现字段映射特别麻烦,还经常遇到编码问题。后来改用Kettle&#xff…...

MaixPy3开发环境搭建避坑指南:从驱动安装到板子连接(MAIX-ll-DOCK实测)

MaixPy3开发环境搭建避坑指南:从驱动安装到板子连接(MAIX-ll-DOCK实测) 当你第一次拿到MAIX-ll-DOCK开发板,准备开始你的嵌入式AI开发之旅时,最令人头疼的往往不是代码本身,而是环境搭建这个看似简单却暗藏…...

Windows 11下Zotero 7与百度网盘的无缝同步配置(含软链接避坑技巧)

Windows 11下Zotero 7与百度网盘的高效同步方案 作为一名长期使用Zotero管理学术文献的研究者,我深刻理解文献同步的重要性。当Zotero 7发布后,许多用户发现原有的ZotFile插件不再兼容,这给依赖云同步的研究者带来了不小困扰。本文将分享我在…...

UniApp小程序包体积超2M?HBuilderX发行模式与miniprogram-ci上传的避坑实战

UniApp小程序包体积优化与自动化发布实战指南 引言:为什么你的小程序包总是超限? 每次看到"main package source size exceed max limit 2048KB"的报错提示,开发者们都会感到一阵头疼。微信小程序严格的包体积限制(主包…...

GLM-OCR模型C语言基础调用示例:嵌入式视觉应用入门

GLM-OCR模型C语言基础调用示例:嵌入式视觉应用入门 如果你是一名C语言开发者,或者正在捣鼓树莓派、ESP32这类嵌入式设备,想给它们加上“眼睛”,让它们能看懂图片里的文字,那你来对地方了。 今天咱们不聊复杂的Python…...

RexUniNLU在舆情预警中的应用:突发事件检测

RexUniNLU在舆情预警中的应用:突发事件检测 1. 引言 社交媒体每天产生海量信息,如何在繁杂的数据中快速识别潜在危机事件,成为企业和机构面临的重要挑战。传统舆情监测往往依赖人工筛选和规则匹配,不仅效率低下,还容…...

【CAN FD调试终极指南】:20年嵌入式老兵亲授C语言实时抓包、错误注入与波形验证的7大避坑法则

第一章:CAN FD协议核心机制与调试本质认知 CAN FD(Flexible Data-Rate)并非CAN 2.0的简单扩展,而是在物理层、数据链路层和帧结构上实现协同演进的确定性实时通信协议。其核心突破在于双速率切换机制:仲裁段保持经典CA…...

hot100 堆专题

1 数组中的第K个最大元素1.1 法一 使用优先队列java中PriorityQueue<>默认是小根堆遍历数组&#xff0c;offer进去当堆的size大于k了&#xff0c;就poll()最后返回peek()堆顶元素&#xff0c;就是第K大的那个class Solution {public int findKthLargest(int[] nums, int …...

收藏!大厂高薪陷阱:月薪7万想跑路,3年百万仍焦虑,程序员必看避坑指南

咱就是说&#xff0c;现在职场人的内耗越来越离谱&#xff0c;尤其是程序员圈子&#xff0c;这种矛盾更是被无限放大。有人拿着月薪7万的高薪却天天想跑路&#xff0c;有人工作三年就年入百万&#xff0c;却依旧焦虑到失眠——这到底是钱没给够&#xff0c;还是我们搞错了职场的…...

FreeACS技术指南:构建企业级TR-069设备管理系统

FreeACS技术指南&#xff1a;构建企业级TR-069设备管理系统 【免费下载链接】freeacs Free TR-069 ACS that can run (mostly) anywhere. 项目地址: https://gitcode.com/gh_mirrors/fr/freeacs 一、问题&#xff1a;传统设备管理的困境与挑战 在网络设备管理领域&…...

OpenClaw健康检查套件:ollama-QwQ-32B驱动的系统状态报告

OpenClaw健康检查套件&#xff1a;ollama-QwQ-32B驱动的系统状态报告 1. 为什么需要智能化的系统健康报告&#xff1f; 去年我管理的一台开发服务器突然宕机&#xff0c;排查时才发现磁盘早已悄悄占满。传统监控工具虽然能采集数据&#xff0c;但需要人工反复检查仪表盘——这…...

紫微斗数为什么总是看不懂?这款AI工具把命盘拆解成6份通俗报告

最近很多朋友跟我聊紫微斗数。这个传统东方命理体系结构严谨&#xff0c;但一堆专业术语往往让人直接头大。 你是不是也一样&#xff1f;对自己的命盘充满好奇&#xff0c;想知道个性特点、事业方向和人生节奏&#xff0c;结果一看那些“星曜”“宫位”“四化”&#xff0c;瞬间…...

AIGlasses_for_navigation中小企业适用:低成本GPU部署无障碍视觉系统

AIGlasses_for_navigation中小企业适用&#xff1a;低成本GPU部署无障碍视觉系统 让AI视觉技术不再高不可攀&#xff0c;用普通GPU也能搭建专业级目标分割系统 1. 项目背景与价值 想象一下&#xff0c;一家中小型科技公司想要开发智能导航产品&#xff0c;但面对动辄数十万的A…...

从零到自动驾驶仿真:用Docker一键部署Autoware+Carla联合仿真环境

从零构建自动驾驶仿真平台&#xff1a;Docker化Autoware与Carla联合环境实战指南 自动驾驶算法的开发离不开高效可靠的仿真测试环境。想象一下&#xff0c;当你刚完成一个改进的路径规划算法&#xff0c;需要在复杂城市道路场景中验证其可靠性时&#xff0c;如果每次测试都要动…...

Granite TimeSeries FlowState R1模型版本管理实践:使用Git与Docker进行迭代

Granite TimeSeries FlowState R1模型版本管理实践&#xff1a;使用Git与Docker进行迭代 你是不是也遇到过这种情况&#xff1f;团队里几个人一起折腾一个时间序列模型&#xff0c;比如这个Granite TimeSeries FlowState R1&#xff0c;今天你改了点训练参数&#xff0c;明天他…...

Qwen3-Reranker-8B在新闻推荐系统的应用:个性化排序实战

Qwen3-Reranker-8B在新闻推荐系统的应用&#xff1a;个性化排序实战 1. 新闻推荐的痛点与破局点 每天打开新闻App&#xff0c;你是否也遇到过这些情况&#xff1a;刚看完一篇关于人工智能的深度报道&#xff0c;接下来推送的却是娱乐八卦&#xff1b;连续刷到三篇相似的财经分…...

嵌入式指纹考勤系统:STM32+AS608+Qt分层架构设计

1. 项目概述指纹考勤系统作为现代办公自动化管理的关键环节&#xff0c;其核心诉求在于身份认证的唯一性、抗抵赖性与操作可追溯性。传统IC卡、密码或机械打卡方式在实际部署中暴露出明显短板&#xff1a;卡片易丢失复制、密码易遗忘泄露、代打卡行为难以杜绝&#xff0c;导致考…...

别再手动打包了!用Jenkins+GitLab搭建你的第一个CI/CD流水线(保姆级图文教程)

从零构建企业级CI/CD流水线&#xff1a;Jenkins与GitLab深度整合实战指南 深夜两点&#xff0c;你揉着酸胀的眼睛&#xff0c;第8次手动执行测试脚本。屏幕上突然弹出的报错让你瞬间清醒——又漏掉了一个依赖项更新。这种场景是否似曾相识&#xff1f;本文将带你彻底告别手工部…...

小白程序员必看!揭秘大模型Agent的核心能力,轻松从“会说”到“能做事”

很多人第一次接触 Agent&#xff0c;最容易产生一种错觉&#xff1a; 只要大模型会调用工具&#xff0c;它就已经是 Agent 了。 再进一步一点的人&#xff0c;会把 Agent 的核心理解成&#xff1a; Prompt 写得好模型能力够强工具接得够多 这些当然都重要。 但如果你真的开始做…...

WPF中打造现代化TreeView:从基础样式到高级交互美化

1. 从零开始构建现代化TreeView样式 如果你正在开发一个需要展示层级结构的WPF应用&#xff0c;比如文件管理器或者系统配置面板&#xff0c;TreeView控件绝对是你的首选。但默认的TreeView样式实在太过简陋&#xff0c;灰白的背景、生硬的线条&#xff0c;完全不符合现代UI设计…...

大模型Agent框架选型与评估实战:小白也能掌握的收藏必备指南!

1. 题目分析 这是一道典型的"经验拷打问题"&#xff0c;三个子问题层层递进&#xff1a;用过什么→怎么选的→怎么评判好坏。面试官不是在考你能列出多少框架名字&#xff0c;而是在判断你有没有真正在生产项目中经历过从选型到落地到评估的完整闭环。很多候选人能把…...

小程序开发实战:5种跨页面数据共享方案性能对比(含代码示例)

小程序开发实战&#xff1a;5种跨页面数据共享方案性能对比&#xff08;含代码示例&#xff09; 在小程序开发中&#xff0c;数据共享是构建复杂应用的基础能力。不同的数据共享方案在性能表现、适用场景和开发体验上存在显著差异。本文将通过基准测试和实际案例&#xff0c;深…...

STM32H7的ECC机制详解:从原理到故障排查(附SRAM/Flash实例)

STM32H7的ECC机制详解&#xff1a;从原理到故障排查&#xff08;附SRAM/Flash实例&#xff09; 引言&#xff1a;为什么ECC对现代嵌入式系统至关重要 在医疗设备控制呼吸机泵送频率、工业PLC记录产线传感器数据时&#xff0c;哪怕是一个比特位的翻转都可能导致灾难性后果。STM3…...

别再让ChatGPT瞎编了!用OpenAI Function Calling接入真实天气API,5分钟搞定实时数据查询

用OpenAI Function Calling构建真实数据驱动的AI应用&#xff1a;以天气查询为例 每次问ChatGPT"今天会下雨吗"&#xff0c;它可能会给你一段充满诗意的回答——但很可能和实际情况毫无关系。这就是大模型"幻觉"问题的典型表现&#xff1a;当需要实时数据…...

手把手教你用Dify的‘知识库’功能,把热点数据喂给AI,打造专属的赛道咨询顾问

零代码打造AI赛道顾问&#xff1a;Dify知识库赋能自媒体热点挖掘新范式 当信息洪流以每秒百万级的速度冲刷各大内容平台时&#xff0c;真正有价值的趋势洞察往往淹没在数据噪音中。传统解决方案要求从业者掌握SQL查询、数据可视化甚至Python爬虫技能&#xff0c;这种技术门槛让…...

Qwen-Image定制镜像开源实操:RTX4090D环境下Qwen-VL微调与推理一体化

Qwen-Image定制镜像开源实操&#xff1a;RTX4090D环境下Qwen-VL微调与推理一体化 1. 镜像概述与环境准备 Qwen-Image定制镜像是专为RTX4090D显卡优化的多模态大模型开发环境&#xff0c;预装了完整的CUDA 12.4工具链和Qwen-VL模型依赖库。这个镜像最大的特点是开箱即用&#…...

从硅视网膜到仿生听觉:类脑传感器DVS/DAS的进化史与开源项目推荐

从硅视网膜到仿生听觉&#xff1a;类脑传感器DVS/DAS的进化史与开源项目推荐 当传统相机还在为帧率、动态范围和功耗苦苦挣扎时&#xff0c;一群科学家正从生物视觉系统中寻找答案。1991年&#xff0c;一位名叫Misha Mahowald的年轻学者在Carver Mead实验室里&#xff0c;将硅芯…...

ChromePass:三分钟高效找回Chrome浏览器所有保存密码的实用方案

ChromePass&#xff1a;三分钟高效找回Chrome浏览器所有保存密码的实用方案 【免费下载链接】chromepass Get all passwords stored by Chrome on WINDOWS. 项目地址: https://gitcode.com/gh_mirrors/chr/chromepass 你是否曾经在登录重要网站时&#xff0c;明明记得在…...