Could not open Hibernate Session for transaction

这个问题,出现的情况是在:

用struts2+hibernate3+spring做的web项目时,部署到外部的linux环境上,第一次登陆的时候就出现这个错误,但是第二次登录就正常了。

问题分析:项目使用的频率不是特别多,这个时候数据库就把连接池中的连接全部释放了,当长时间后(一天)再次登录的时候就会出现这个异常,第二次登录正常。

问题解决方案:1.在链接数据库的url中添加autoReconnect=true(设置重链接,默认为false,即不链接)

    2.在c3p0数据源中设定

<!-- 每xxx秒检查所有连接池中的空闲连接 -->
<property name="idleConnectionTestPeriod" value="1800"/>
<!-- 定义所有连接测试都执行的测试语句。在使用连接测试的情况下这个一显著提高测试速度。注意: 
测试的表必须在初始数据源的时候就存在 -->
<property name="preferredTestQuery" value="select * from 表名 where id = 1"/>
<!-- -如果设为true那么在取得连接的同时将校验连接的有效性。Default: false -->
<property name="testConnectionOnCheckin" value="true"/>
<!-- 因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection提交的 
时候都将校验其有效性。建议使用idleConnectionTestPeriod或automaticTestTable 
等方法来提升连接测试的性能。Default: false -->
<property name="testConnectionOnCheckout" value="true"/>

   3.<property name="hibernateProperties">
<props>
<!-- 设置重链接,值为true -->
<prop key="hibernate.autoReconnect">true</prop>
</props>
</property>


好了,问题解决。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值