【YashanDB 知识库】YashanDB JDBC 驱动查询时抛出 io fail:Read timed out 异常

本文内容来自 YashanDB 官网,原文内容请见  https://yashandb.com/newsinfo/7849026.html?templateId=1718516

业务在执行 SQL 语句时抛出了 io fail:Read timed out 异常,堆栈如下:

WARN com.yashandb.SessionImpl -- Discarding SQLException on close: This socket has been closed.

com.yashandb.jdbc.exception.YasException: io fail:Read timed out

at com.yashandb.jdbc.exception.SQLError.createSQLException(Unknown Source)

at com.yashandb.protocol.NativeProtocol.receivePacket(Unknown Source)

at com.yashandb.protocol.NativeProtocol.sendCommand(Unknown Source)

at com.yashandb.SessionImpl.a(Unknown Source)

at com.yashandb.SessionImpl.a(Unknown Source)

at com.yashandb.SessionImpl.a(Unknown Source)

at com.yashandb.SessionImpl.b(Unknown Source)

at com.yashandb.SessionImpl.a(Unknown Source)

at com.yashandb.SessionImpl.a(Unknown Source)

at com.yashandb.SessionImpl.execute(Unknown Source)

at com.yashandb.jdbc.PreparedStatementImpl.b(Unknown Source)

at com.yashandb.jdbc.PreparedStatementImpl.executeQuery(Unknown Source)

问题原因:SQL 语句的执行时间超过了 JDBC 连接 url 参数中 socketTimeout 指定的时间 (单位为秒),或者是中间件类似参数 (例如 druid 的 socket-timeout,单位为毫秒) 指定的时间。

解决方案:优化 SQL 语句减少执行时间或者调大对应的参数设置


请使用浏览器的分享功能分享到微信等