`
Feiing
  • 浏览: 240394 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Atomikos JTA for Hibernate3

阅读更多
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 时会出一些问题
分享到:
评论
1 楼 81261686 2007-11-25  
  也有用atomikos做JTA,一切操作正常,但不知为什么停tomcat事老有:
Exception in thread "Thread-6" java.lang.NullPointerException
at com.atomikos.icatch.system.Configuration.removeResource(Unknown Source)
at com.atomikos.jdbc.JtaDataSourceImp.close(Unknown Source)
at com.atomikos.jdbc.DataSourceShutdownHook.run(Unknown Source)
Exception in thread "Thread-14" java.lang.NullPointerException
at com.atomikos.icatch.system.Configuration.removeResource(Unknown Source)
at com.atomikos.jdbc.JtaDataSourceImp.close(Unknown Source)
at com.atomikos.jdbc.DataSourceShutdownHook.run(Unknown Source)
错误,不知道是什么原因

相关推荐

    Spring boot+Atomikos+JTA+Hibernate+MySQL实现分布式事务+多数据源(可运行)

    本项目使用Spring Boot、Atomikos、JTA(Java Transaction API)、Hibernate和MySQL来实现分布式事务处理和多数据源管理,以确保在多个数据库操作之间保持事务的ACID特性。 首先,Spring Boot作为微服务开发的主流...

    Spring boot+Atomikos+JTA+Hibernate+mybatis+MySQL实现分布式事务+多数据源

    本案例主要探讨如何利用Spring Boot、Atomikos、JTA(Java Transaction API)、Hibernate以及MyBatis,结合MySQL数据库,实现一个跨数据源的分布式事务解决方案。 首先,Spring Boot是一个基于Spring框架的快速开发...

    atomikos-transactions-hibernate3.jar.zip

    Atomikos Transactions for Hibernate3.jar是专门为Hibernate3集成的版本,它允许开发者在使用Hibernate进行数据库操作时,享受到事务管理的高级功能。Hibernate3是一个流行的对象关系映射(ORM)框架,它简化了Java...

    atomikos-jta-camel-jpa-jms-example:带有 Camel、Spring、JPA 和 JMS 的 Atomikos JTA 示例

    - `pom.xml`:Maven 或 Gradle 的构建文件,定义了项目依赖,如 Atomikos、Spring、Camel、JPA 实现(如 Hibernate)和 JMS 提供商(如 ActiveMQ)。 - `src/main/java`:包含 Java 代码,如 Spring 配置类、Camel ...

    spring 结合druid和hibernate使用jta配置分布式事务

    本篇将详细讲解如何在Spring环境中结合Druid数据源和Hibernate ORM框架,利用Atomikos实现JTA(Java Transaction API)来配置分布式事务。 首先,`Spring` 是一个开源的应用框架,它提供了AOP(面向切面编程)和DI...

    spring + hibernate + atomikos + mysql (diff database)

    3. **Atomikos**:Atomikos是一个实现了JTA的事务管理器,它能够协调跨多个数据库的事务,确保ACID(原子性、一致性、隔离性和持久性)属性。在"diff database"的场景下,Atomikos扮演关键角色,处理涉及两个不同...

    atomikos-jta-jpa-jms-example:带有 Spring、JPA 和 JMS 的 Atomikos JTA 示例

    1. `pom.xml` 文件:包含了项目的依赖,如 Spring、Atomikos、JPA 实现(例如 Hibernate)和 JMS 客户端库(如 ActiveMQ 或 Apache Qpid)。 2. `applicationContext.xml`:Spring 配置文件,定义了 Atomikos 事务...

    spring-jta-atomikos:JTA,JPA,Hibernate和Atomikos的Spring项目

    标题中的“spring-jta-atomikos”是一个关于在Spring框架中使用JTA(Java Transaction API)和Atomikos的项目。JTA是Java平台中用于管理分布式事务的标准API,而Atomikos是一个开源的事务管理器,它支持JTA,并且在...

    atomikos-transactions-jta.jar.zip

    5. **易于集成**:Atomikos 提供了简单的API和配置选项,可以轻松地集成到Spring、Hibernate等框架中,简化开发工作。 `atomikos-transactions-jta.jar` 文件是Atomikos Transactions JTA库的二进制发行版,包含...

    Spring4+Hibernate4+Atomikos3.3多数据源事务管理

    这时,Atomikos作为一个开源的JTA(Java Transaction API)实现,就显得尤为重要。Atomikos3.3支持分布式事务,能够在多个数据源之间协调事务,确保ACID(原子性、一致性、隔离性和持久性)特性。 在集成Atomikos到...

    spring+hibernate+atomikos多数据源

    同时,需要启用Hibernate的JTA事务管理,并指定Atomikos作为事务协调器。 4. 配置Spring:在Spring的配置文件中,为每个数据源创建一个PlatformTransactionManager Bean,使用Atomikos的JtaTransactionManager。...

    第二部分spring+hibernate+jta 分布式事务Demo

    Atomikos jta 的jar包 博文链接:https://momoko8443.iteye.com/blog/190994

    Spring3.1+Hibernate4.1+Atomikos3.9+MySql5.1+Tomcat5/6/7实现JTA事务管理

    `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规范的...

    spring hibernate atomikos 分布式事务

    Atomikos是Java中的一款开源的事务管理器,尤其适用于处理JTA(Java Transaction API)级别的分布式事务。它能够使不同的数据源(如数据库、消息队列等)在同一事务中协同工作,确保数据的一致性。在Spring框架中,...

    Spring3.0+Hibernate+Atomikos多数据源分布式事务管理

    **Atomikos**: Atomikos是一款开源的JTA事务管理器,它实现了Java Transaction API (JTA) 和 Java Transaction Service (JTS)。在分布式环境中,Atomikos可以帮助协调跨多个数据源的事务,确保ACID(原子性、一致性...

    Atomikos 3.6.4

    在Hibernate集成方面,`transactions-hibernate3-3.6.4.jar` 文件专门针对流行的ORM(对象关系映射)框架Hibernate进行了优化。它允许Hibernate应用程序利用Atomikos的事务管理功能,确保在复杂的数据库操作中保持...

    Atomikos分布式事务处理所需jar包 4.0.4版本

    8. **transactions-hibernate3-4.0.4.jar**:这个库专为Hibernate ORM框架设计,使Hibernate能够在分布式事务中正常工作。它将Atomikos的事务管理功能与Hibernate的持久化层无缝集成。 在实际开发中,使用Atomikos...

Global site tag (gtag.js) - Google Analytics