
在 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 或类似的“网络适配器无法建立连接”消息,这明确指出问题根源在于网络层面或连接配置。
此类错误通常发生在以下场景:
解决这类问题需要系统性地检查配置和网络环境。
这是最常见也是最直接的原因。应用程序的 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
关键检查点:
案例分析: 原始问题中的 URL 为 jdbc:oracle:thin:@bodswv092:1521:DEMO。如果 bodswv092 主机名、1521 端口或 DEMO 服务名有任何一个与实际数据库配置不符,就会导致连接失败。最常见的情况是主机名或 IP 地址错误。
即使配置看起来正确,网络本身的问题也可能阻止连接。
Ping 数据库主机: 在运行 Quarkus 应用的服务器上,尝试 ping <数据库主机名或IP>。如果 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”或长时间无响应,则表明端口不可达。
“Unable to acquire JDBC Connection”并伴随“The Network Adapter could not establish the connection”错误,几乎总是指向数据库连接配置错误或网络连通性问题。解决此问题的关键在于:首先,仔细核对 application.properties 中的数据库 URL、主机名、端口和服务名是否完全正确;其次,利用 ping 和 telnet/nc 等网络工具验证从应用服务器到数据库服务器的网络可达性和端口开放情况;最后,检查两端的防火墙设置和数据库服务及监听器的运行状态。 通过系统性的排查,通常可以迅速定位并解决这类连接故障。
以上就是Quarkus 应用中 JDBC 连接异常排查与解决的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号