0

接続プールに Hibernate + C3P0 を使用するアプリケーションを Spring(yfying) しています。特定の理由で、管理された休止状態コンテキストを使用しています。セッション処理にユーティリティ クラス「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.cfg.xml を使用する代わりに、hibernate.transaction.factory_class を指定し、hibernate プロパティを Spring Bean 構成に移動しようとしましたが、すべて役に立ちませんでした。まだ Spring トランザクション管理に完全に切り替えることはできません。

4

1 に答える 1

1

私見では、すべてをSpringに移行するようにしてください。私の経験では、混同すると多くの問題が発生します。以下を使用してSpring Managed Transaction Managementをまだ設定できない特定の理由はありますか?

<!-- 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>

あなたの説明から、問題が発生している正確な場所を見つけるのは非常に困難です。それは、トランザクションまたはセッションファクトリーですか? hibernateProperties の外部で dataSource を使用するときに sessionFactory の問題を引き起こす可能性があるもう 1 つのポイントは、Hibernate が使用している ConnectionProvider 実装が変更されていることです。dataSourceHibernate が使用することを指定するとDataSourceConnectionProvider( http://docs.jboss.org/hibernate/orm/3.6/javadocs/org/hibernate/connection/DatasourceConnectionProvider.html )、hibernate 構成でデータ ソースを設定すると、Hibernate はDriverManagerConnectionProvider( http://docs.jboss.org/hibernate/orm/3.2/api/org/hibernate/connection/DriverManagerConnectionProvider.html) これら 2 つの違いが問題の原因である可能性があります。

于 2013-05-15T12:03:33.003 に答える