0

0

Quarkus 应用中 JDBC 连接异常排查与解决

碧海醫心

碧海醫心

发布时间:2025-09-30 22:53:01

|

671人浏览过

|

来源于php中文网

原创

Quarkus 应用中 JDBC 连接异常排查与解决

本文旨在解决 Quarkus/Hibernate 应用中常见的“无法获取 JDBC 连接”错误,特别是当出现“网络适配器无法建立连接”的底层问题时。核心解决方案在于仔细检查并修正 application.properties 文件中数据库连接配置的准确性,包括主机名、端口、服务名/SID以及认证信息,并结合网络连通性工具进行系统性排查,确保应用能够正确访问数据库服务。

理解“无法获取 JDBC 连接”错误

在 quarkus 或其他 java 应用中,当使用 hibernate 等 orm 框架尝试连接数据库时,如果遇到 javax.persistence.persistenceexception: org.hibernate.exception.jdbcconnectionexception: unable to acquire jdbc connection 错误,通常意味着应用程序无法建立与数据库的物理连接。如果进一步的堆信息显示 java.sql.sqlrecoverableexception: erreur d'e/s: the network adapter could not establish the connection 或类似的“网络适配器无法建立连接”消息,这明确指出问题根源在于网络层面或连接配置。

此类错误通常发生在以下场景:

  1. 数据库服务器地址或端口不正确:应用程序尝试连接到一个不存在或监听在错误端口的地址。
  2. 防火墙阻止连接:客户端机器或数据库服务器上的防火墙阻止了应用程序与数据库端口之间的通信。
  3. 数据库服务未运行或监听器故障:数据库实例或其网络监听器(如 Oracle Listener)没有正常启动。
  4. 网络路由问题:客户端机器无法通过网络路径到达数据库服务器。

核心排查与解决步骤

解决这类问题需要系统性地检查配置和网络环境。

1. 验证数据库连接配置

这是最常见也是最直接的原因。应用程序的 application.properties 文件中数据库连接字符串、用户名或密码的任何微小错误都可能导致连接失败。

以 Oracle 数据库为例,请仔细检查以下配置项:

# 数据库类型,例如 Oracle
quarkus.datasource.db-kind=oracle
# JDBC 连接 URL
quarkus.datasource.jdbc.url=jdbc:oracle:thin:@<数据库主机名或IP>:<端口>:<服务名或SID>
# 数据库用户名
quarkus.datasource.username=<你的用户名>
# 数据库密码
quarkus.datasource.password=<你的密码>

# 可选:连接池配置
# quarkus.datasource.jdbc.max-size=20
# quarkus.datasource.jdbc.min-size=5

关键检查点:

Draft&Goal-Detector
Draft&Goal-Detector

检测文本是由 AI 还是人类编写的

下载
  • quarkus.datasource.jdbc.url
    • :确保这是数据库服务器的正确网络地址。例如,原始问题中的 bodswv092 必须是数据库服务器的有效主机名或 IP 地址。如果使用主机名,请确保 DNS 解析正确。
    • :确认数据库监听器正在此端口上运行。Oracle 默认端口通常是 1521。
    • :对于 Oracle,这可以是服务名(如 DEMO)或系统标识符 (SID)。确保它与数据库实例的配置匹配。
  • quarkus.datasource.usernamequarkus.datasource.password:虽然“网络适配器无法建立连接”通常不是认证问题,但一旦网络连接成功,错误的凭据将导致下一个阶段的错误。因此,也要确保这些是正确的。

案例分析: 原始问题中的 URL 为 jdbc:oracle:thin:@bodswv092:1521:DEMO。如果 bodswv092 主机名、1521 端口或 DEMO 服务名有任何一个与实际数据库配置不符,就会导致连接失败。最常见的情况是主机名或 IP 地址错误。

2. 检查网络连通性

即使配置看起来正确,网络本身的问题也可能阻止连接。

  • Ping 数据库主机: 在运行 Quarkus 应用的服务器上,尝试 ping 。如果 ping 不通,说明存在基本的网络可达性问题(如主机不存在、网络不通、防火墙阻止 ICMP)。

    ping bodswv092
  • Telnet 或 Netcat 检查端口可达性: 这是最关键的步骤之一。它能检查特定端口是否在数据库服务器上开放并可访问。

    # 对于 Linux/macOS
    telnet <数据库主机名或IP> <端口>
    # 例如:
    telnet bodswv092 1521
    
    # 或者使用 nc (netcat)
    nc -vz <数据库主机名或IP> <端口>
    # 例如:
    nc -vz bodswv092 1521

    如果 telnet 命令成功连接(通常会显示连接信息并进入空白界面),说明网络连接到该端口是成功的。如果显示“Connection refused”、“No route to host”或长时间无响应,则表明端口不可达。

3. 检查防火墙设置

  • 客户端防火墙:确保运行 Quarkus 应用的服务器没有出站规则阻止其连接到数据库的端口。
  • 服务器防火墙:确保数据库服务器的防火墙(如 Linux 上的 firewalld 或 iptables,Windows 上的 Windows Defender 防火墙)允许来自应用服务器 IP 的入站连接到数据库端口(例如 1521)。

4. 确认数据库服务状态

  • 数据库实例是否运行? 登录到数据库服务器,确认数据库实例是否已启动。
  • 数据库监听器是否运行? 对于 Oracle,监听器(Listener)负责接受传入的连接请求。使用数据库工具(如 lsnrctl status)检查监听器状态。

最佳实践与注意事项

  • 使用环境变量管理敏感信息:对于生产环境,数据库凭据等敏感信息不应直接硬编码在 application.properties 中,而应通过环境变量、Kubernetes Secrets 或配置管理工具注入。Quarkus 支持通过 quarkus.datasource.username=${DB_USERNAME} 这种方式引用环境变量。
  • 详细日志记录:确保应用程序的日志级别设置为适当的级别(如 INFO 或 DEBUG),以便在连接失败时能获取更多详细的错误信息。Quarkus 默认日志通常已经足够。
  • 逐步测试:在开发过程中,可以先使用一个简单的 JDBC 客户端(如 sqlplus、DBeaver 或一个简单的 Java 程序)从应用服务器尝试连接数据库,以排除 Quarkus/Hibernate 配置之外的问题。
  • DNS 解析:如果数据库主机名无法解析,尝试直接使用 IP 地址进行连接,以排除 DNS 问题。

总结

“Unable to acquire JDBC Connection”并伴随“The Network Adapter could not establish the connection”错误,几乎总是指向数据库连接配置错误或网络连通性问题。解决此问题的关键在于:首先,仔细核对 application.properties 中的数据库 URL、主机名、端口和服务名是否完全正确;其次,利用 ping 和 telnet/nc 等网络工具验证从应用服务器到数据库服务器的网络可达性和端口开放情况;最后,检查两端的防火墙设置和数据库服务及监听器的运行状态。 通过系统性的排查,通常可以迅速定位并解决这类连接故障。

相关文章

夸克浏览器
夸克浏览器

夸克Quark是一款采用 chromium 单核设计,网页渲染加载速度快,还有 0.3s 闪电启动的极速体验。内置隐私防护功能,能多方面保护用户隐私,可识别各种恶意软件和钓鱼网站,确保上网安全。与夸克网盘一体设计,拥有夸克高考、夸克搜题等多种智能工具,还有超过上万条过滤规则的超强去广告功能,以及智能拼页的阅读模式等。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

727

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

328

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

350

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1263

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

360

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

821

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

581

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

423

2024.04.29

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

2

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.6万人学习

Java 教程
Java 教程

共578课时 | 52.8万人学习

oracle知识库
oracle知识库

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号