- 浏览: 36636 次
- 性别:
- 来自: 杭州
最新评论
-
ykdsg:
我想问下rehash()方法中 // 将lastRun之后的整 ...
并发容器分析(五)--ConcurrentHashMap -
borland:
刚才测试了,性能比LinkedBlockingQueue好50 ...
并发容器分析(四)--ConcurrentLinkedQueue
一、简介
在Spring和EJB中事务管理都是业务逻辑开发的重点,在spring2和EJB3之后都对事务管理进行了简化,更多得采用声明式(可通过注解)接口来开发事务。在典型的事务管理中,主要的关注点有三个:事务传播、事务隔离和事务回滚。
事务传播是指事务上下文Transactional Context如何在调用链中传播;事务隔离是指并发的事务相互之间不产生干扰;事务回滚涉及当产生异常时,系统如何响应,在什么样的情况下将事务进行回滚。
笔记中主要记录上述三个概念以及比较在spring2.5和EJB3中不同的处理方法。
二、事务传播
当一个Bean的方法在事务上下文(Transactional Context)中执行时,它可以将自己所在的Transactional Context传播到它所调用的方法中。事务传播的规则由事务属性定义,通常的事务属性分为如下六个值:
NotSupported/Supports
Required/RequiresNew
Mandatory/Never
他们的意义如下:
NotSupported/Supports 事务会在调用具有NotSupported属性的方法时被挂起,直到方法执行完毕,即事务不会被传入具有NotSupported属性及其调用的方法中,当该方法执行完毕后原事务将恢复;Supports事务属性表明,当一个Bean的方法在某个事务范围内被调用时,该方法将加入这个事务范围,同时它也可以和未包含在事务范围内的Bean交互。
Required/RequiresNew Required属性表明该方法必须在一个事务范围内执行,若发起调用的客户端属于一个事务范围内,则该Bean也会将自己加入该事务范围。若调用者不属于任何事务范围,则Required Bean将发起一个新的事务,当方法执行完之后事务随即结束。
RequiresNew表明,当对该Bean的方法调用时,总会产生一个新的事务范围,当方法结束时事务也会终止。
Mandatory/Never Mandatory表明方法必须在发起调用的客户端的事务范围内执行,若调用端不属于任何事务范围,则调用将失败;Never则相反,它表明方法决不能在事务范围内被调用,若调用端属于某个事务范围,则调用将失败。
事务的传播过程将由环境来监控,如果传播过程中任意一项操作失败,则整个事务就会失败。
三、事务隔离
事务的隔离性条件是指当多个事务对相同数据进行操作可能的结果,隔离条件包括脏读、不可重复读、幻读。
脏读 当某一事务读取了另一事务修改之后尚未提交的数据时,就会产生脏读问题。若另一事务被回滚,则它所做的修改将被撤销,此前读取的数据将会是一个无效值。
不可重复读 在某一事务两次读取同一数据之间,另一事务修改了该数据,导致两次读取的数据不同,这就是不可重复读问题。
幻读 如果添加到数据库中的新数据在执行实际的插入操作之前可以被其他的事务检测到,就会出现幻读问题。
可以通过使用数据库的不同锁定技术来解决如上的三个问题,常见的三种类型的锁如下:读锁、写锁、排他写锁。
对应的,数据库中有如下几个隔离级别:
Read Uncommitted 事务可以读取未被提交的数据,可能产生上述三种问题。
Read Committed 事务不能读取未被递交的数据,可以避免脏读。
Repeatable Read 事务不能修改其他事务正在读取的数据,可避免脏读和不可重复读问题
Serializable 将事务进行串行化处理,可以避免所有的问题
以上几个隔离级别隔离性越强,对性能的影响就越大,需要根据实际业务做出平衡。
四、异常和事务
事务管理中常常将异常分为两类:系统异常和应用异常。
系统异常 代表未知的内部错误,当应用服务器发生内部错误时往往就会抛出系统异常,当希望终止业务流程的执行时,业务逻辑也可以抛出系统异常。系统异常包括java.lang.RuntimeException及其子类,当业务逻辑中抛出系统异常时一定会引起事务的回滚。
应用异常 应用异常往往代表一种业务逻辑的错误,它会被抛出到调用端以做出适当的响应,默认情况下应用异常并不会引起事务的回滚。
五、Spring中的事务管理
Spring框架为事务处理提供了一致的抽象,它为复杂的事务API(如JTA、Hibernate、JDBC)提供了一致的编程模型,并支持声明式事务。
Spring提供了一个抽象的事务策略接口:org.springframe.transaction.PlatformTransactionManager
public interface PlatformTransactionManager{ TransactionStatus getTransaction(TransactionDefinition d) throws TransactionException; void commit(TransactionStatus s) throws TransactionException; void rollback(TransactionStatus s) throws TransactionException; }
这是一个SPI接口,可以使用JTA、Hibernate、JDBC等方法实现,最终在框架中提供了统一的事务API。
在Spring中可以用两种配置方式使用事务:基于XML的配置和Annotations的配置
5.1、基于XML的事务配置
首先要定义一个正确的PlatformTransactionManager实现,如采用Hibernate的实现定义如下:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="mappingResources"> <list> <value>org/springframework/samples/petclinic/hibernate/petclinic.hbm.xml</value> </list> </property> <property name="hibernateProperties"> <value> hibernate.dialect=${hibernate.dialect} </value> </property> </bean> <bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory" /> </bean>
Spring的声明式事务支持是通过Spring AOP代理来实现的,事务方面的代码与Spring绑定并以一种模板风格的方式使用(如HibernateTemplate),AOP代理使用一个PlatformTransactionManager的具体实现配合TransactionInterceptor在方法调用前后实施事务管理。
在XML的声明式事务配置中也使用了AOP类似的配置方法
<bean id="fooService" class="x.y.service.DefaultFooService"/> <tx:advice id="txAdvice" transaction-manager="txManager"> <tx:attributes> <!-- all methods starting with 'get' are read-only --> <tx:method name="get*" read-only="true"/> <!-- other methods use the default transaction settings (see below) --> <tx:method name="*"/> </tx:attributes> </tx:advice> <aop:config> <aop:pointcut id="fooServiceOperation" expression="execution(* x.y.service.FooService.*(..))"/> <aop:advisor advice-ref="txAdvice" pointcut-ref="fooServiceOperation"/> </aop:config>
上述配置中,<tx:advice />定义了一个事务通知,在<aop:config />中将该通知应用到合适的点上。
5.2、使用@Transactional配置
除了使用XML配置外,Spring还支持基于注解的事务配置。可以使用@Transactional注解定义Bean的事务属性
@Transactional(readOnly = true) public class DefaultFooService implements FooService { public Foo getFoo(String fooName) { // do something } @Transactional(readOnly = false, propagation = Propagation.REQUIRES_NEW) public void updateFoo(Foo foo) { // do something } }
同时需要在xml配置文件中定义注解驱动:
<bean id="fooService" class="x.y.service.DefaultFooService"/> <!-- enable the configuration of transactional behavior based on annotations --> <tx:annotation-driven transaction-manager="txManager"/> <!-- a PlatformTransactionManager is still required --> <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <!-- (this dependency is defined somewhere else) --> <property name="dataSource" ref="dataSource"/> </bean>
发表评论
-
并发容器分析(五)--ConcurrentHashMap
2010-10-13 22:20 2910一、简介 ConcurrentHashMap是Map ... -
并发容器分析(四)--ConcurrentLinkedQueue
2010-10-13 22:20 2394一、简介 ConcurrentLinkedQueue ... -
并发容器分析(三)--LinkedBlockingQueue
2010-10-13 22:19 3304一、简介 LinkedBlockingQueue是B ... -
并发容器分析(二)--ArrayBlockingQueue
2010-10-13 22:19 5369一、简介 BlockingQueue接口定义了一种阻 ... -
并发容器分析(一)--CopyOnWriteArrayList
2010-10-13 22:19 8070一、简介 JDK5中添加了新的concurrent包 ... -
JGroups通讯协议(三)--FD_ALL
2009-08-02 21:28 0一、简介 FD协议层用于错误诊断,它们使用心跳检测的 ... -
JGroups通讯协议(二)--PING
2009-08-02 14:12 0一、简介 PING协议 ... -
JGroups通讯协议(一)--UDP
2009-08-02 10:33 0一、简介 UDP是JGroups中默认的通讯协议,它 ... -
JGroups代码分析(二)--协议栈ProtocolStack
2009-07-31 21:11 0一、简介 ProtocolStack是JGroup ... -
JGroups代码分析(一)--编程接口JChannel
2009-07-31 20:19 0一、简介 JGroups是 ... -
netty代码分析(五)--ServerBootstrap
2009-07-23 20:20 0一、简介 ServerBootstrap类封装了服务 ... -
netty代码分析(四)--NioWorker
2009-07-23 19:50 0一、简介 一个NioWorker对象拥有一个独立的线 ... -
netty代码分析(三)--ChannelSink
2009-07-23 19:22 0一、简介 ChannelSink是Downstrea ... -
netty代码分析(二)--ChannelPipeline
2014-10-20 12:45 735一、简介 ChannelPipeline是事件(e ... -
netty代码分析(一)--总体设计
2014-10-20 12:44 611一、简介 Netty3是一个轻量级的NIO框架,它 ... -
Ehcache(二)--Store实现
2009-07-10 15:58 0一、简介 Ehcache中实际的数据存储是由Stor ... -
Ehcache(一)--接口
2009-07-10 15:01 0一、简介 Ehcache是一个从Hibernate ... -
JBoss Cache(四)--Evict策略
2009-07-08 21:47 0一、简介 cache系统在缓存数据达到一定数量后,在 ... -
JBoss Cache(三)--MVCC策略
2009-07-08 15:27 0一、简介 JBoss Cache3.0中加入了MVC ... -
JBoss Cache(二)--核心数据结构
2009-07-08 14:41 0一、简介 在采用command/visitor模式之 ...
相关推荐
在本篇“Spring Hibernate 事务管理学习笔记(二)”中,我们将深入探讨Spring框架与Hibernate集成时如何实现高效、安全的事务管理。这是一篇关于源码分析和技术工具使用的文章,适合对Java开发和数据库操作有基础...
TCC模式是一种典型的分布式事务管理模式,通过Try、Confirm和Cancel三个阶段来实现事务的一致性。 - **Try阶段**:尝试执行操作,预留必要的资源。 - **Confirm阶段**:确认操作,释放之前预留的资源。 - **Cancel...
在学习过程中,阅读博客如《spring hibernate 事务管理学习笔记(一)》是非常有益的,它通常会包含具体的示例代码和实践建议。你可以参考这个博客链接(https://microjava.iteye.com/blog/525973),结合实际项目,...
在本篇“Spring.NET学习笔记16——事务管理Demo源码”中,我们将深入探讨Spring.NET的事务管理机制及其实际应用。 事务管理是软件开发中的关键部分,它确保数据库操作的一致性和完整性。Spring.NET通过其事务管理...
在IT行业中,SSH(Spring、Struts、Hibernate)是一个经典的Java Web开发框架组合,而这里的“SSH笔记-事务管理”主要关注的是Spring框架中的事务管理部分。Spring以其强大的依赖注入和面向切面编程能力,提供了灵活...
这篇笔记将深入探讨SQL Server中的事务管理。 一、事务的四大特性(ACID) 1. 原子性(Atomicity):事务中的所有操作被视为一个单元,即使部分操作失败,整个事务也会被回滚,确保数据的完整性。 2. 一致性...
项目管理是确保项目目标得以实现的重要管理活动,它涉及到一系列的计划、组织、指导和控制项目资源的活动。项目经理在其中扮演着至关重要的角色,需要具备极强的主动性和责任感,以及足够的项目投入。本文档是关于...
本笔记将重点讨论Spring中的AOP(面向切面编程)以及事务管理,同时简述JDBC中的事务处理。 1. **Spring AOP回顾** - Spring的AOP允许我们定义横切关注点,如日志、安全检查等,这些关注点可以被编织到应用程序...
在Spring框架中,事务管理是核心功能之一,它确保了数据的一致性和完整性。这篇"Spring学习笔记(18)----使用Spring配置文件实现事务管理"着重讲解如何通过Spring的XML配置来管理应用中的事务。这里我们将深入探讨...
这个笔记集合可能是由知名讲师韩顺平教授的课程或教程整理而来,旨在帮助学习者理解和掌握如何使用Java来设计和实现一个功能完备的学生管理系统。 【描述】:“韩顺平java笔记,学生管理系统管理”这部分内容不仅...
个人事务管理系统是一种计算机应用系统,旨在帮助个人更好地管理自己的日常事务、任务和事件。下面是个人事务管理系统的一些关键知识点: 1. 个人事务管理系统的目的:个人事务管理系统的主要目的是帮助个人更好地...
Visual C++(简称VC++)作为Microsoft公司开发的一种强大的Windows平台下的编程工具,结合MFC(Microsoft Foundation Classes)库,可以构建高效、用户友好的应用程序,如“学生个人事务管理系统”。本篇文章将深入...
在本篇“Spring学习笔记(十五)——编程式事务例子”中,我们将深入探讨Spring框架中的编程式事务管理。在实际开发中,我们通常使用声明式事务管理,它基于AOP(面向切面编程)来简化事务处理。然而,有时为了更细...
这里使用了`DataSourceTransactionManager`作为事务管理器,它是Spring中最常用的事务管理器之一,适用于JDBC事务。 ##### 2. 启动事务注解 要在Spring应用中启用基于注解的事务管理,需要在配置类中添加@...
这里,`DataSourceTransactionManager`是Spring提供的一个事务管理器,它与数据源相关联。 3. **@Transactional注解的属性** `@Transactional`注解有多个属性,包括`propagation`(传播行为)、`isolation`(隔离...
在Spring框架中,声明式事务管理是其核心特性之一,它允许开发者通过配置来控制事务的行为,而无需在代码中显式地管理事务的开始、提交、回滚等操作。这种方式使得事务管理更加灵活,也使得代码更加简洁,易于维护。...
信息系统管理工程师复习笔记涵盖了诸多专业知识点,是软考信息系统管理工程师考试的复习资料。以下知识点的详细解读: 1. CPU架构与组成:内容中涉及了CPU的基本组成,如控制单元(CU),算术逻辑单元(ALU),以及缓存...
数据库系统是管理数据库的软件系统,支持数据的存储、查询、更新和事务管理。 8. 性能评估 计算机性能评估涉及多个指标,如MIPS(每秒百万条指令)、MFLOPS(每秒百万次浮点运算)、MTBF(平均无故障时间)、MTTR...
【个人事务管理系统】是一种以用户为中心的软件应用,旨在帮助用户高效地组织、跟踪和管理他们的日常事务。这种系统通常包含日程安排、任务管理、提醒功能、笔记记录以及项目协作等多个模块,使得用户能够更好地规划...
【标题】:“韩顺平oracle视频笔记四(事务)”主要涵盖了Oracle数据库系统中的事务管理这一核心主题。在Oracle数据库中,事务是数据库操作的基本单位,它确保了数据的一致性和完整性。本视频笔记可能详细讲解了事务...