gpt4 book ai didi

java - 如何处理应用程序运行时数据库关闭时发生的 MySQL CommunicationException

转载 作者:行者123 更新时间:2023-11-29 09:49:19 25 4
gpt4 key购买 nike

Spring Boot 应用程序使用 MySQL + C3p0 数据源
我用这个数据源与JDBCJPA(提供者Hibernate)一起工作。

在每个 JDBC DAO 层方法中,我都有 try/catch SQLException。这个catch block 确实捕获了这个 通信异常但是..

但是当我尝试发送越来越多的请求时,我开始有了这个堆栈跟踪。

com.mysql.cj.jdbc.exceptions.CommunicationsException:通信链路失败

Caused by: java.net.ConnectException: Connection refused: connect

+许多细节..

最后我在SQLException catch block 中捕获:

java.sql.SQLException: Connections could not be acquired from the underlying database!

在此消息之前应用程序看起来像它无法连接但它知道
非常快给出带有 500 状态代码的响应。

此消息之后应用程序看起来像它尝试连接但无法理解它不能。在这种情况下,它会非常缓慢给出响应。

打开数据库后,应用程序无需重新启动即可运行。

最佳答案

大堆栈跟踪可能由运行应用程序的 Web 服务器打印。可能不是来自您的代码。您需要阅读有关您的网络服务器的信息,了解如何避免此类堆栈跟踪打印。

关于java - 如何处理应用程序运行时数据库关闭时发生的 MySQL CommunicationException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55093318/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com