【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语句减少执行时间或者调大对应的参数设置

posted @   YashanDB  阅读(6)  评论(0编辑  收藏  举报
编辑推荐:
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
阅读排行:
· [翻译] 为什么 Tracebit 用 C# 开发
· 腾讯ima接入deepseek-r1,借用别人脑子用用成真了~
· Deepseek官网太卡,教你白嫖阿里云的Deepseek-R1满血版
· DeepSeek崛起:程序员“饭碗”被抢,还是职业进化新起点?
· RFID实践——.NET IoT程序读取高频RFID卡/标签
点击右上角即可分享
微信分享提示