Spring SQLRecoverableException:错误de E/S连接中止:recv失败

Spring SQLRecoverableException:错误de E/S连接中止:recv失败,spring,jakarta-ee,spring-mvc,mybatis,ibatis,Spring,Jakarta Ee,Spring Mvc,Mybatis,Ibatis,我与数据库的连接有问题,在应用程序中一段时间不活动后,我返回输入并向我发送以下错误 01-08-2014 04:45:33 PM org.apache.catalina.core.StandardWrapperValve invoke GRAVE: Servlet.service() para servlet springapp lanzó excepción org.springframework.dao.DataAccessResourceFailureException: ### Err

我与数据库的连接有问题,在应用程序中一段时间不活动后,我返回输入并向我发送以下错误

01-08-2014 04:45:33 PM org.apache.catalina.core.StandardWrapperValve invoke
GRAVE: Servlet.service() para servlet springapp lanzó excepción
org.springframework.dao.DataAccessResourceFailureException: 
### Error querying database.  Cause: java.sql.SQLRecoverableException: Error de E/S: Software caused connection abort: recv failed
这是我的oracle数据源

<!-- Load properties with PlaceHolder -->
<context:property-placeholder location="WEB-INF/properties/*.properties" />

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    <property name="driverClassName"    value="${jdbc.driverClassName}"/>
    <property name="url"                value="${jdbc.url}" />
    <property name="username"           value="${jdbc.username}" />
    <property name="password"           value="${jdbc.password}" />
</bean>

<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource"/>  
</bean>

<aop:config>
    <!-- aop:advisor pointcut="execution(* *..Service.*(..))" advice-ref="txAdvice"/ -->
    <aop:pointcut id="fooServiceOperation" expression="execution(* cl.bbr.proceso.maestro.proceso.ProcesoMaestro.*(..))"/>
    <aop:advisor advice-ref="txAdvice" pointcut-ref="fooServiceOperation"/>
</aop:config>

<tx:advice id="txAdvice" transaction-manager="txManager">
    <tx:attributes>
        <!-- all methods starting with 'get','is','select' are read-only -->
        <tx:method name="get*" read-only="true"/>
        <tx:method name="is*" read-only="true"/>
        <tx:method name="select*" read-only="true"/>
        <!-- other methods use the default transaction settings (see below) -->
        <tx:method name="*" rollback-for="Exception" />
    </tx:attributes>
</tx:advice>

<tx:advice id="noTxAdvice" transaction-manager="txManager">
    <tx:attributes>
        <tx:method name="*" propagation="REQUIRES_NEW" />
    </tx:attributes>
</tx:advice>

2014年8月5日编辑 数据库:ORACLE 11G SPRING版本:3.0 TOMCAT 6.0


希望您能帮助我,谢谢。

将这些行添加到dataSource bean解决了问题:

<property name="validationQuery" value="SELECT 1 from dual" /> 
<property name="testOnBorrow" value="true" />

关于验证查询,您可以在该问题的答案中阅读:


“testOnBorrow”意味着在每次执行查询之前,都将执行validationQuery。

请指定您的web服务器、db引擎、spring版本。尝试添加到数据源bean中。这将在每次请求之前检查连接。感谢它为我工作的时间,你能更好地解释一下这段代码的作用吗?或者我可以在哪里找到这方面的文档。再次感谢,我将其作为回应发布,以表明其正确性。问候语。