gpt4 book ai didi

java - 这个 java MySQL 异常的原因(和处理)是什么?

转载 作者:行者123 更新时间:2023-11-29 05:45:41 26 4
gpt4 key购买 nike

在一段时间不活动后执行第一个准备语句时出现以下异常:

com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

The last packet successfully received from the server was 2,855,054 milliseconds ago. The last packet sent successfully to the server was 123 milliseconds ago.
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
at java.lang.reflect.Constructor.newInstance(Unknown Source)
at com.mysql.jdbc.Util.handleNewInstance(Util.java:406)
at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1074)
at com.mysql.jdbc.MysqlIO.reuseAndReadPacket(MysqlIO.java:3052)
at com.mysql.jdbc.MysqlIO.reuseAndReadPacket(MysqlIO.java:2938)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3481)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1959)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2109)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2648)
at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2077)
at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:2228)

这仅在我的应用程序最近未与 MySQL 通信时才会显示。后续查询正常执行。我怀疑这是某种超时问题,但不活动时间远低于 MySQL 的 8 小时超时。

有什么建议吗?

最佳答案

你在使用连接池吗?如果是这样,您可以只打开连接池检查/监视,这样您就可以确保您的客户端线程每次都能获得有效的 MySQL 连接。大多数池都有一种方法可以指定在借用连接之前或有时甚至在空闲期间在后台执行的省力 SQL 片段(为了获得更好的性能,但可能会向客户端线程发出一些错误的连接)。

此外,w.r.t. time < 8h 问题,MySQL 是否从收到的最后一个数据包或最后一个重要事件(查询等)开始计算空闲时间?我记得在 MySQL 驱动程序代码中看到实现了心跳信号。

关于java - 这个 java MySQL 异常的原因(和处理)是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2489426/

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