首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

【第九章】 Spring的事务 之 9.2 事务管理器 ——跟小弟我学spring3

2012-07-15 
【第九章】 Spring的事务 之 9.2 事务管理器 ——跟我学spring39.2.1? 概述?????? Spring框架支持事务管理的核

【第九章】 Spring的事务 之 9.2 事务管理器 ——跟我学spring3

9.2.1? 概述

?????? Spring框架支持事务管理的核心是事务管理器抽象,对于不同的数据访问框架(如Hibernate)通过实现策略接口PlatformTransactionManager,从而能支持各种数据访问框架的事务管理,PlatformTransactionManager接口定义如下:

?

java代码:
java代码:
java代码:

【第九章】 Spring的事务 之 9.2 事务管理器 ——跟小弟我学spring3

图9-1 Spring事务管理器

?

?????? 接下来让我们学习一下如何在Spring配置文件中定义事务管理器:

?

一、声明对本地事务的支持:

a)JDBC及iBATIS、MyBatis框架事务管理器

?

java代码:

?

通过dataSource属性指定需要事务管理的单个javax.sql.DataSource对象。

b)Jdo事务管理器

?

java代码:

?

通过persistenceManagerFactory属性指定需要事务管理的javax.jdo.PersistenceManagerFactory对象。

?

c)Jpa事务管理器

?

java代码:

?

通过entityManagerFactory属性指定需要事务管理的javax.persistence.EntityManagerFactory对象。

还需要为entityManagerFactory对象指定jpaDialect属性,该属性所对应的对象指定了如何获取连接对象、开启事务、关闭事务等事务管理相关的行为。

?

java代码:
java代码:

通过entityManagerFactory属性指定需要事务管理的org.hibernate.SessionFactory对象。

?

?

二、Spring对全局事务的支持:

?

a)Jta事务管理器

?

?

java代码:

?

“dataSource”Bean表示从JNDI中获取的数据源,而txManager是JTA事务管理器,其中属性transactionManagerName指定了JTA事务管理器的JNDI名字,从而将事务管理委托给该事务管理器。

?

这只是最简单的配置方式,更复杂的形式请参考Spring Javadoc。

?

在此我们再介绍两个不依赖于应用服务器的开源JTA事务实现:JOTM和Atomikos Transactions Essentials。

JOTM即基于Java开放事务管理器(Java Open Transaction Manager),实现JTA规范,能够运行在非应用服务器环境中,Web容器或独立Java SE环境,官网地址: http://jotm.objectweb.org/。Atomikos Transactions Essentials其为Atomikos开发的事务管理器,该产品属于开源产品,另外还一个商业的Extreme Transactions。官网地址为:http://www.atomikos.com。

对于以上JTA事务管理器使用,本文作者只是做演示使用,如果在实际项目中需要不依赖于应用服务器的JTA事务支持,需详细测试并选择合适的。

?

在本文中将使用Atomikos Transactions Essentials来进行演示JTA事务使用,由于Atomikos对hsqldb分布式支持不是很好,在Atomikos官网中列出如下兼容的数据库:Oracle、Informix、FirstSQL、DB2、MySQL、SQLServer、Sybase,这不代表其他数据库不支持,而是Atomikos团队没完全测试,在此作者决定使用derby内存数据库来演示JTA分布式事务。

?

1、首先准备jar包:

?

1.1、准备derby数据jar包,到下载的spring-framework-3.0.5.RELEASE-dependencies.zip中拷贝如下jar包:

?

java代码:

? ? ?在此我们配置两个分布式数据源:使用com.atomikos.jdbc.AtomikosDataSourceBean来配置AtomikosTransactionsEssentials分布式数据源:

uniqueResourceName表示唯一资源名,如有多个数据源不可重复;xaDataSourceClassName是具体分布式数据源厂商实现;poolSize是数据连接池大小;xaProperties属性指定具体厂商数据库属性,如databaseName指定数据库名,createDatabase表示启动derby内嵌数据库时创建databaseName指定的数据库。

?

在此我们还有定义了一个“dataSource2”Bean,其属性和“DataSource1”除以下不一样其他完全一样:

uniqueResourceName:因为不能重复,因此此处使用jdbc/test2;databaseName:我们需要指定两个数据库,因此此处我们指定为test2。

?

2.2、配置事务管理器:

?

java代码:
b)特定服务器事务管理器

Spring还提供了对特定应用服务器事务管理器集成的支持,目前提供对IBM WebSphere、BEA WebLogic、 Oracle OC4J应用服务器高级事务的支持,具体使用请参考Spring Javadoc。

?

?

现在我们已经学习如何配置事务管理器了,但是只有事务管理器Spring能自动进行事务管理吗?当然不能了,这需要我们来控制,目前Spring支持两种事务管理方式:编程式和声明式事务管理。接下来先看一下如何进行编程式事务管理吧。

?

原创内容,转载请注明出处【http://sishuok.com/forum/blogPost/list/0/2503.html】

?

2 楼 ak913 2012-03-25   按逻辑,datasource与transaction manager应该在配置上有所关联,不然transaction manager无法得知要管理哪个datasource的commit及rollback。
在对本地事务的介绍中,这个关联在配置中已设定。
但在Atomikos JTA的配置中,datasource与transaction manager的设置似乎各自完全独立,毫无关联。
请教栏主,这。。。是何道理?
3 楼 jinnianshilongnian 2012-03-25   ak913 写道按逻辑,datasource与transaction manager应该在配置上有所关联,不然transaction manager无法得知要管理哪个datasource的commit及rollback。
在对本地事务的介绍中,这个关联在配置中已设定。
但在Atomikos JTA的配置中,datasource与transaction manager的设置似乎各自完全独立,毫无关联。
请教栏主,这。。。是何道理?


Atomikos JTA 中使用的分布式事务,使用的是两阶段提交协议,建议您去看一下 分布式事务概念

热点排行