zoukankan      html  css  js  c++  java
  • spring+ibatis问题1—— 程序报错:java.sql.SQLException: Io 异常: Connection reset by peer, socket write error; ”或“java.sql.SQLException 关闭的连接”异常

    转自:http://blog.sina.com.cn/s/blog_1549fb0710102whz2.html

      spring+ibatis程序测试时报错:java.sql.SQLException: Io 异常: Connection reset by peer, socket write error; 

        sql-map-config.xml配置:

          <transactionManager type="JDBC" >
            <dataSource type="DBCP">
              <property value="${drivers}" name="JDBC.Driver" />
              <property value="${url}" name="JDBC.ConnectionURL" />
              <property value="${user}" name="JDBC.Username" />
              <property value="${password}" name="JDBC.Password" />
              <property value="${maxActive}" name="Pool.MaximumActiveConnections" />
              <property value="${maxIdle}" name="Pool.MaximumIdleConnections" />
              <property value="${maxWait}" name="Pool.MaximumWait" />
    <property name="validationQuery" value="select * from dual"/>
            </dataSource>
          </transactionManager>  

        该问题主要是由于连接时间过长,失效所致,将sql-map-config.xml中的“dataSource”配置修改如下:

          <transactionManager type="JDBC" > 
            <dataSource type="DBCP">
              <property value="${drivers}" name="JDBC.Driver" />
              <property value="${url}" name="JDBC.ConnectionURL" />
              <property value="${user}" name="JDBC.Username" />
              <property value="${password}" name="JDBC.Password" />
              <property value="${maxActive}" name="Pool.MaximumActiveConnections" />
              <property value="${maxIdle}" name="Pool.MaximumIdleConnections" />
              <property value="${maxWait}" name="Pool.MaximumWait" />
              <property name="validationQuery" value="select * from dual"/>
            </dataSource>
          </transactionManager>

        当数据库连接池中的连接被创建而长时间不使用的情况下,该连接会自动回收并失效,但客户端并不知道,在进行数据库操作时仍然使用的是无效的数据库连接,这样,就导致客户端程序报“ java.sql.SQLException: Io 异常: Connection reset by    peer, socket write error; ”或“java.sql.SQLException 关闭的连接”异常,加上 

              <property name="validationQuery" value="select * from dual"/>

    配置后,客户端在使用一个无效的连接时会先对该连接进行测试,如果发现该连接已经无效,则重新从连接池获取有效数据库连接来使用。

      注意:网络不稳定或网络信号差也会报这种异常。

      

  • 相关阅读:
    概率与数学期望初步
    $Luogu$ $P4316$ 绿豆蛙的归宿(附期望 $dp$ 的设计总结)
    $Luogu$ $P4427$ $[BJOI2018]$ 求和
    $SP3978$ $DISQUERY$ $-$ $Distance$ $Query$
    最近公共祖先模板(未完待续)
    $Luogu$ $P3052$ $[USACO12MAR]$ 摩天大楼里的奶牛 $Cows$ $in$ $a$ $Skyscraper$
    $Luogu$ $P2622$ 关灯问题 $mathrm{II}$
    [转载] $CF633F$ 题解
    [转载] $Luogu$ $P3933$ 题解
    2020高考回忆录(随便写写
  • 原文地址:https://www.cnblogs.com/kylyww/p/6221505.html
Copyright © 2011-2022 走看看