/ / Міграція в сплячку керувала пулом C3P0 на Spring Managed - java, spring, hibernate, сделки, c3p0

Перемістити керований Hibernate C3P0 Pool до Spring Managed - java, spring, hibernate, transactions, c3p0

Я весна (іфікую) свою програму, яка використовуєЗимова сплячка + C3P0 для пулу з'єднань. Я використовую керований контекст сплячки з конкретних причин. Я використовую клас утиліти "HibernateUtil" для обробки сеансу. Для першої міграції до Spring я створюю ApplicationContext і отримую боб SessionFactory в HibernateUtil, замінюючи код, який використовувався для створення SessionFactory. Коли я повністю створюю заводський бобовий сеанс зі свого старого hibernate.cfg.xml навесні, все працює як слід:

<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 та переміщення властивостей сплячки до конфігурації Spring bean замість того, щоб використовувати hibernate.cfg.xml все безрезультатно. Я не можу повністю перейти до управління весняними транзакціями.

Відповіді:

1 для відповіді № 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, є те, що застосовується реалізація ConnectionProvider Hibernate. Якщо ви вкажете a dataSource Буде використовувати сплячку DataSourceConnectionProvider(http://docs.jboss.org/hibernate/orm/3.6/javadocs/org/hibernate/connection/DatasourceConnectionProvider.html) тоді як для встановлення джерела даних у сплячому режимі Hibernate буде використовувати DriverManagerConnectionProvider (http://docs.jboss.org/hibernate/orm/3.2/api/org/hibernate/connection/DriverManagerConnectionProvider.html) Різниці між цими двома можуть бути причиною ваших проблем.