将Hibernate托管的C3P0池迁移到Spring Managed

时间:2013-05-14 17:55:14

标签: java spring hibernate transactions c3p0

我是Spring(yfying)我的应用程序,它使用Hibernate + C3P0作为连接池。我出于特定原因使用托管的hibernate上下文。我正在使用实用程序类“HibernateUtil”进行会话处理。对于第一次迁移到Spring,我正在创建一个ApplicationContext并在HibernateUtil中检索SessionFactory bean,替换用于构建SessionFactory的代码。当我从Spring中的旧hibernate.cfg.xml完全创建会话工厂bean时,一切都按预期工作:

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">

    <property name="configLocation" value="classpath:config/hibernate.cfg.xml"></property>

  </bean>

的hibernate.cfg.xml

<hibernate-configuration>

<session-factory>

<property name="connection.username">user</property>
    <property name="connection.url">jdbc:mysql://localhost:3306/mydb?zeroDateTimeBehavior=convertToNull</property>
    <property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
    <property name="connection.password">pass</property>
    <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
    <property name="hibernate.max_fetch_depth">3</property>
    <property name="hibernate.current_session_context_class">org.hibernate.context.ManagedSessionContext</property>
    <property name="hibernate.transaction.auto_close_session">false</property>


    <property name="hibernate.cache.region.factory_class">
         net.sf.ehcache.hibernate.SingletonEhCacheRegionFactory</property>
    <property name="hibernate.cache.use_query_cache">true</property>
    <property name="hibernate.cache.use_second_level_cache">true</property>
    <property name="hibernate.show_sql">true</property>
    <property name="query.substitutions">true 1, false 0, yes 'Y', no 'N'</property>

    <!-- configuration pool via c3p0--> 

    <property name="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
    <property name="connection.isolation">2</property>

    <property name="hibernate.c3p0.acquire_increment">3</property> 
    <property name="hibernate.c3p0.idle_test_period">120</property> <!-- seconds --> 
    <property name="hibernate.c3p0.max_size">100</property> 
    <property name="hibernate.c3p0.max_statements">50</property> 
    <property name="hibernate.c3p0.min_size">3</property> 
    <property name="hibernate.c3p0.timeout">1800</property> 

    <!-- mapping files -->
   .......

如果我将连接池外部化(我也从hibernate.cfg.xml中删除了所有连接设置),我的事务就无法正常工作。

<bean id="myDataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
     <property name="driverClass" value="${db.driver}"/>
     <property name="jdbcUrl" value="${db.url}"/>
     <property name="user" value="${db.user}"/>
     <property name="password" value="${db.pass}"/>

  </bean>

      <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
        <property name="dataSource" ref="myDataSource"/>
        <property name="configLocation" value="classpath:config/hibernate.cfg.xml"></property>

      </bean>

我已经尝试过指定hibernate.transaction.factory_class并将hibernate属性移动到Spring bean配置而不是使用hibernate.cfg.xml都无济于事。我还不能完全切换到Spring Transaction管理。

1 个答案:

答案 0 :(得分:1)

你应该尝试将所有东西都搬到春天。根据我的经验,混合起来会有很多问题。是否有一个特殊原因导致您无法使用以下方式设置弹簧管理的事务管理:

<!-- Transaction Management -->
    <tx:annotation-driven transaction-manager="txManager" proxy-target-class="true"/>
    <bean id="txManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory" />
    </bean>

根据您的描述,找出与交易或sessionFactory一起出现问题的确切位置是非常困难的?   在hibernateProperties之外使用dataSource时,可能导致sessionFactory问题的另一点是Hibernate正在使用的ConnectionProvider实现正在发生变化。如果指定dataSource Hibernate将使用DataSourceConnectionProviderhttp://docs.jboss.org/hibernate/orm/3.6/javadocs/org/hibernate/connection/DatasourceConnectionProvider.html)而在hibernate配置中设置数据源时Hibernate将使用DriverManagerConnectionProviderhttp://docs.jboss.org/hibernate/orm/3.2/api/org/hibernate/connection/DriverManagerConnectionProvider.html)    这两者之间的差异可能是导致问题的原因。