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

标签 java mysql jdbc

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

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/

相关文章:

java - 如何在java中创建utf-8编码的文件,以便在 Notepad++ /记事本或任何其他文本编辑器中打开时显示为UTF-8编码

java - 没有这样的列 _id Android、Java、SQL

mysql - 哪种数据库技术适用于大结构化数据?

java - 为什么数据库连接一直关闭

java - 调用 rs.next() 或 rs.previous() 时结果集指针的增量不均匀

java - 使用 jquery 使用 Spring mvc Web 服务

java - SQLException "No value specified for parameter 3"

mysql - 从插入语句中检索 UUID

mysql - 我想检查我的 sql 命令是否包含输入的数据

mysql - 为什么这个 SQL 在 MySQL 中执行而不是通过 Eclipse?