http://wiki.atomikos.org/bin/view.pl/Main/HibernateIntegration#With_Spring
http://www.hibernate.org/hib_docs/v3/reference/en/html/transactions.html#transactions-connection-release
经过多次试验, 下面的配置是最合适的 (OpenSessionInView Works fine)
jta.properties
com.atomikos.icatch.service = com.atomikos.icatch.standalone.UserTransactionServiceFactory
#Do you want transaction logging to be enabled or not?
#If set to false, then no logging overhead will be done
#at the risk of losing data after restart or crash.
#Note: this setting may be overridden depending on your license!
com.atomikos.icatch.enable_logging = false
com.atomikos.icatch.automatic_resource_registration = true
xa datasource and jta transaction manager
<bean id="system.datasource"
class="com.atomikos.jdbc.SimpleDataSourceBean" init-method="init" destroy-method="close">
<property name="uniqueResourceName"><value>XADBMS</value></property>
<property name="xaDataSourceClassName">
<value>com.mysql.jdbc.jdbc2.optional.MysqlXADataSource</value>
</property>
<property name="xaDataSourceProperties">
<value>url=${jdbc.url};user=${jdbc.username};password=${jdbc.password};pinGlobalTxToPhysicalConnection=true</value>
</property>
<property name="exclusiveConnectionMode"><value>false</value></property>
<property name="connectionPoolSize"><value>10</value></property>
</bean>
<bean id="system.sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource" ref="system.datasource"/>
<property name="jtaTransactionManager" ref="atomikosTransactionManager" />
<property name="mappingDirectoryLocations">
<list>
<value>classpath:/com/coheg/</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.query.substitutions">true ${boolean.true.value}, false ${boolean.false.value}, yes ${boolean.true.value}, no ${boolean.false.value}</prop>
<prop key="hibernate.dialect">${hibernate.dialect}</prop>
<prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
<prop key="hibernate.format_sql">true</prop>
<!-- for jta compatilibility -->
<prop key="current_session_context_class">jta</prop>
<prop key="hibernate.transaction.factory_class">org.hibernate.transaction.JTATransactionFactory</prop>
<prop key="hibernate.connection.release_mode">after_statement</prop>
</props>
</property>
</bean>
<!-- Construct Atomikos UserTransactionManager, needed to configure Spring -->
<bean id="atomikosTransactionManager" class="com.atomikos.icatch.jta.UserTransactionManager" init-method="init" destroy-method="close">
<!-- when close is called, should we force transactions to terminate or not? -->
<property name="forceShutdown"><value>true</value></property>
</bean>
<!-- Also use Atomikos UserTransactionImp, needed to configure Spring -->
<bean id="atomikosUserTransaction" class="com.atomikos.icatch.jta.UserTransactionImp">
<property name="transactionTimeout"><value>120000</value></property>
</bean>
<!-- Configure the Spring framework to use JTA transactions from Atomikos -->
<bean id="system.platformTransactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">
<property name="transactionManager"><ref bean="atomikosTransactionManager" /></property>
<property name="userTransaction"><ref bean="atomikosUserTransaction" /></property>
</bean>
hibernate2 不支持 Connection Release Mode 概念, 在使用 JTA + OpenSessionInView 时会出一些问题
分享到:
相关推荐
本项目使用Spring Boot、Atomikos、JTA(Java Transaction API)、Hibernate和MySQL来实现分布式事务处理和多数据源管理,以确保在多个数据库操作之间保持事务的ACID特性。 首先,Spring Boot作为微服务开发的主流...
本案例主要探讨如何利用Spring Boot、Atomikos、JTA(Java Transaction API)、Hibernate以及MyBatis,结合MySQL数据库,实现一个跨数据源的分布式事务解决方案。 首先,Spring Boot是一个基于Spring框架的快速开发...
Atomikos Transactions for Hibernate3.jar是专门为Hibernate3集成的版本,它允许开发者在使用Hibernate进行数据库操作时,享受到事务管理的高级功能。Hibernate3是一个流行的对象关系映射(ORM)框架,它简化了Java...
- `pom.xml`:Maven 或 Gradle 的构建文件,定义了项目依赖,如 Atomikos、Spring、Camel、JPA 实现(如 Hibernate)和 JMS 提供商(如 ActiveMQ)。 - `src/main/java`:包含 Java 代码,如 Spring 配置类、Camel ...
本篇将详细讲解如何在Spring环境中结合Druid数据源和Hibernate ORM框架,利用Atomikos实现JTA(Java Transaction API)来配置分布式事务。 首先,`Spring` 是一个开源的应用框架,它提供了AOP(面向切面编程)和DI...
3. **Atomikos**:Atomikos是一个实现了JTA的事务管理器,它能够协调跨多个数据库的事务,确保ACID(原子性、一致性、隔离性和持久性)属性。在"diff database"的场景下,Atomikos扮演关键角色,处理涉及两个不同...
1. `pom.xml` 文件:包含了项目的依赖,如 Spring、Atomikos、JPA 实现(例如 Hibernate)和 JMS 客户端库(如 ActiveMQ 或 Apache Qpid)。 2. `applicationContext.xml`:Spring 配置文件,定义了 Atomikos 事务...
"多数据源事务之解决方案jta+atomikos"这个主题正是针对这一挑战提出的。JTA(Java Transaction API)和Atomikos是两个关键的组件,它们一起为Java应用提供了强大的分布式事务管理能力。 首先,JTA是Java平台企业版...
标题中的“spring-jta-atomikos”是一个关于在Spring框架中使用JTA(Java Transaction API)和Atomikos的项目。JTA是Java平台中用于管理分布式事务的标准API,而Atomikos是一个开源的事务管理器,它支持JTA,并且在...
5. **易于集成**:Atomikos 提供了简单的API和配置选项,可以轻松地集成到Spring、Hibernate等框架中,简化开发工作。 `atomikos-transactions-jta.jar` 文件是Atomikos Transactions JTA库的二进制发行版,包含...
这时,Atomikos作为一个开源的JTA(Java Transaction API)实现,就显得尤为重要。Atomikos3.3支持分布式事务,能够在多个数据源之间协调事务,确保ACID(原子性、一致性、隔离性和持久性)特性。 在集成Atomikos到...
同时,需要启用Hibernate的JTA事务管理,并指定Atomikos作为事务协调器。 4. 配置Spring:在Spring的配置文件中,为每个数据源创建一个PlatformTransactionManager Bean,使用Atomikos的JtaTransactionManager。...
Atomikos jta 的jar包 博文链接:https://momoko8443.iteye.com/blog/190994
`transactions-jta-3.9.1.jar`, `transactions-jdbc-3.9.1.jar`, `transactions-hibernate3-3.9.1.jar`, `transactions-3.9.1.jar`, `atomikos-util-3.9.1.jar` 这些库是Atomikos的组成部分,它们提供了JTA规范的...
Atomikos是Java中的一款开源的事务管理器,尤其适用于处理JTA(Java Transaction API)级别的分布式事务。它能够使不同的数据源(如数据库、消息队列等)在同一事务中协同工作,确保数据的一致性。在Spring框架中,...
**Atomikos**: Atomikos是一款开源的JTA事务管理器,它实现了Java Transaction API (JTA) 和 Java Transaction Service (JTS)。在分布式环境中,Atomikos可以帮助协调跨多个数据源的事务,确保ACID(原子性、一致性...
在Hibernate集成方面,`transactions-hibernate3-3.6.4.jar` 文件专门针对流行的ORM(对象关系映射)框架Hibernate进行了优化。它允许Hibernate应用程序利用Atomikos的事务管理功能,确保在复杂的数据库操作中保持...