spring+hibernate+c3p0整合链接池配置-连接无法释放问题(已经解决)

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"  
  4.  xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"  
  5.  xmlns:aop="http://www.springframework.org/schema/aop"  
  6.  xsi:schemaLocation="  
  7.  http://www.springframework.org/schema/beans  
  8.  http://www.springframework.org/schema/beans/spring-beans-3.2.xsd  
  9.  http://www.springframework.org/schema/context  
  10.  http://www.springframework.org/schema/context/spring-context-3.2.xsd  
  11.  http://www.springframework.org/schema/tx  
  12.  http://www.springframework.org/schema/tx/spring-tx-3.2.xsd  
  13.  http://www.springframework.org/schema/aop  
  14.  http://www.springframework.org/schema/aop/spring-aop-3.2.xsd"  
  15.  default-autowire="byName">  
  16.  <context:property-placeholder location="classpath:jdbcConfig.properties" />  
  17.  <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"  
  18.   destroy-method="close">  
  19.   <property name="driverClass" value="${jdbc.driverClassName}" />  
  20.   <property name="jdbcUrl" value="${jdbc.url}" />  
  21.   <property name="user" value="${jdbc.username}" />  
  22.   <property name="password" value="${jdbc.password}" />  
  23.   <property name="minPoolSize" value="5" />  
  24.   <property name="maxPoolSize" value="20" />  
  25.   <property name="maxStatements" value="10" />  
  26.   <property name="idleConnectionTestPeriod" value="3000" />  
  27.   <property name="loginTimeout" value="300" />  
  28.  </bean>  
  29.  <bean id="sessionFactory"  
  30.   class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">  
  31.   <property name="dataSource">  
  32.    <ref local="dataSource" />  
  33.   </property>  
  34.   <property name="hibernateProperties">  
  35.    <props>  
  36.     <prop key="hibernate.show_sql">true</prop>  
  37.     <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>  
  38.     <prop key="hibernate.format_sql">true</prop>  
  39.     <prop key="hibernate.use_sql_comments">true</prop>  
  40.    </props>  
  41.   </property>  
  42.   <property name="packagesToScan" value="com" />  
  43.  </bean>  
  44.  <context:component-scan base-package="com" />  
  45.  <!-- 事务管理器 -->  
  46.  <bean id="transactionManager"  
  47.   class="org.springframework.orm.hibernate3.HibernateTransactionManager">  
  48.   <property name="sessionFactory" ref="sessionFactory" />  
  49.   <property name="dataSource">  
  50.    <ref local="dataSource" />  
  51.   </property>  
  52.  </bean>  
  53.  <!-- 支持事务 @Transactional 标记 -->  
  54.  <tx:annotation-driven transaction-manager="transactionManager" />  
  55. </beans>  


以上配置是spring+hibernate+c3p0整合链接池配置,通过代码全注解的方式增加事物管理,连接池等

前不久一直被一个问题困扰着,
getHibernateTemplate().getSessionFactory().openSession();
通过这种方式打开的session不会自动关闭,现象时查询多次之后连接池满了,不会再继续查询了
日志信息如下
[plain]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. 2014-06-06 15:16:50,654 [btpool0-4] DEBUG AbstractBeanFactory : Returning cached instance of singleton bean 'transactionManager'  
  2. 2014-06-06 15:16:50,655 [btpool0-4] DEBUG AbstractPlatformTransactionManager : Creating new transaction with name [com.*.*.service.ActivityService.findAllByPage]: PROPAGATION_REQUIRED,ISOLATION_DEFAULT; ''  
  3. 2014-06-06 15:16:50,655 [btpool0-4] DEBUG HibernateTransactionManager : Opened new Session [org.hibernate.impl.SessionImpl@4bdc0bc7] for Hibernate transaction  
  4. 2014-06-06 15:16:50,655 [btpool0-4] DEBUG HibernateTransactionManager : Preparing JDBC Connection of Hibernate Session [org.hibernate.impl.SessionImpl@4bdc0bc7]  
  5. 2014-06-06 15:16:50,655 [btpool0-4] DEBUG BasicResourcePool : trace com.mchange.v2.resourcepool.BasicResourcePool@7bfbfeae [managed: 20, unused: 0, excluded: 0] (e.g. com.mchange.v2.c3p0.impl.NewPooledConnection@564389b7)  
  6. 2014-06-06 15:16:50,656 [btpool0-4] DEBUG HibernateTransactionManager : Exposing Hibernate transaction as JDBC transaction [com.mchange.v2.c3p0.impl.NewProxyConnection@6a02938d]  
  7. 2014-06-06 15:16:50,657 [btpool0-4] DEBUG BasicResourcePool : acquire test -- pool is already maxed out. [managed: 20; max: 20]  
  8. 2014-06-06 15:16:50,657 [btpool0-4] DEBUG BasicResourcePool : awaitAvailable(): com.mchange.v2.c3p0.impl.NewPooledConnection@564389b7  
  9. 2014-06-06 15:16:50,658 [btpool0-4] DEBUG BasicResourcePool : trace com.mchange.v2.resourcepool.BasicResourcePool@7bfbfeae [managed: 20, unused: 0, excluded: 0] (e.g. com.mchange.v2.c3p0.impl.NewPooledConnection@564389b7)  




后来通过网上查找资料看到这么一篇内容

这个是hibernate与spring整合开发,让DAO继承了spring的HibernateDaoSupport,这样的确能够提高开发效率 ,但是不够灵活,而且使DAO层依赖于spring的api,增加了耦合。但是不考虑复用的话还可以。

    下面一个一个的分析: this.getsession实际上是调用了父类中的方法获得session。使用spring管理hibernate的SessionFactory的时候,这个方法会从session池中拿出一session.这样做有可能有问题,就是超session池连接数的时候,spring无法自动的关闭session。 不推荐使用

     this.getHibernateTemplate().getSessionFactory().getCurrentSession()从spring管理的sessionFactory中创建一个绑定线程的session.spring会根据该线程的执行情况来自动判断是关闭session还是延迟关闭。这样做可以避免手动的管理实务,同时一个线程最多开启和关闭一次session又可以提高程序的性能。 极力推荐使用这种方法 

     this.getHibernateTemplate().getSessionFactory().OpenSession。这种方法从spring管理的sessionFactory中创建一个session,此session不是线程绑定的。当执行完一个实务的时候自动关闭session.这种方法不用手动管理实务,但是同一个线程多次的开启和关闭session,浪费系统资源和影响执行效率,正常情况下还是不要用了。


其中this.getSession这个方法我也用过,这个确实也会将连接关闭,当时对于楼主提到的问题不知道怎么测试,

第二个问题完美的解决了,我遇到的连接池无法关闭的问题而且楼主也推荐使用,应该找到最终的解决办法了

第三个,就是我前面一直用的,需要手动关闭连接


对于网上还有一种说法,

http://bbs.csdn.net/topics/340092096

问题已经解决,原来在配置hibernater时少配了一个属性:
<prop key="hibernate.connection.release_mode">after_statement</prop>
唉!不懂是此属性值默认是on_close,就是session.close();时关闭连接,但我在调用这查询时,使用手动session.close();还是一样的结果。。。。


该配置对于我来说一点用都没有,不知道是什么场景下使用


不过总算搞定连接池问题了,已经工作的时候,也经常听别人说你们要用getCurrentSession,而不要新开连接,新开的需要自己手动关闭,大概道理就是这个了


转载地址;http://blog.csdn.net/yonglelaoren/article/details/28886593

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值