Spring事务传播机制

传播性行为分为以下几种

PROPAGATION_REQUIRED–支持当前事务,如果当前没有事务,就新建一个事务。这是最常见的选择。
PROPAGATION_SUPPORTS–支持当前事务,如果当前没有事务,就以非事务方式执行。
PROPAGATION_MANDATORY–支持当前事务,如果当前没有事务,就抛出异常。
PROPAGATION_REQUIRES_NEW–新建事务,如果当前存在事务,把当前事务挂起。
PROPAGATION_NOT_SUPPORTED–以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
PROPAGATION_NEVER–以非事务方式执行,如果当前存在事务,则抛出异常。

ServiceA {
   /**
    * 事务属性配置为 PROPAGATION_REQUIRED
    */
   void method() {
      try {
               ServiceB.method(); 
              } catch (SomeException) {
                // 执行其他业务
               }
            }
     }

PROPAGATION_REQUIRED

比如说,ServiceB.method的事务级别定义为PROPAGATION_REQUIRED, 那么由于执行ServiceA.method的时候,
ServiceA.method已经起了事务,这时调用ServiceB.method,ServiceB.method看到自己已经运行在ServiceA.method
的事务内部,就不再起新的事务。而假如ServiceA.method运行的时候发现自己没有在事务中,他就会为自己分配一个事务。这样,在ServiceA.method或者在ServiceB.method内的任何地方出现异常,事务都会被回滚。即使ServiceB.method的事务已经被提交,但是ServiceA.method在接下来fail要回滚,ServiceB.method也要回滚。

PROPAGATION_SUPPORTS

如果当前在事务中,即以事务的形式运行,如果当前不再一个事务中,那么就以非事务的形式运行

PROPAGATION_MANDATORY

必须在一个事务中运行。也就是说,他只能被一个父事务调用。否则,他就要抛出异常

PROPAGATION_REQUIRES_NEW

我们设计ServiceA.method的事务级别为PROPAGATION_REQUIRED,ServiceB.method的事务级别为PROPAGATION_REQUIRES_NEW,那么当执行到ServiceB.method的时候,ServiceA.method所在的事务就会挂起,ServiceB.method会起一个新的事务,等待ServiceB.method的事务完成以后,他才继续执行。他与PROPAGATION_REQUIRED 的事务区别在于事务的回滚程度了。因为ServiceB.method是新起一个事务,那么就是存在
两个不同的事务。如果ServiceB.method已经提交,那么ServiceA.method失败回滚,ServiceB.method是不会回滚的。如果ServiceB.method失败回滚,如果他抛出的异常被ServiceA.method捕获,ServiceA.method事务仍然可能提交。

PROPAGATION_NOT_SUPPORTED

比如ServiceA.method的事务级别是PROPAGATION_REQUIRED ,而ServiceB.method的事务级别是PROPAGATION_NOT_SUPPORTED ,
那么当执行到ServiceB.method时,ServiceA.method的事务挂起,而ServiceB.method以非事务的状态运行完,再继续ServiceA.method的事务。

PROPAGATION_NEVER

假设ServiceA.method的事务级别是PROPAGATION_REQUIRED, 而ServiceB.method的事务级别是PROPAGATION_NEVER ,那么ServiceB.method就要抛出异常了。

PROPAGATION_NESTED

理解Nested的关键是savepoint。他与PROPAGATION_REQUIRES_NEW的区别是,PROPAGATION_REQUIRES_NEW另起一个事务,将会与他的父事务相互独立,而Nested的事务和他的父事务是相依的,他的提交是要等和他的父事务一块提交的。也就是说,如果父事务最后回滚,他也要回滚的。而Nested事务的好处是他有一个savepoint。

ServiceA {

/**
* 事务属性配置为 PROPAGATION_REQUIRED
*/
void method() {
try {
//savepoint
ServiceB.method(); //PROPAGATION_NESTED 级别
} catch (SomeException) {
// 执行其他业务
ServiceC.method();
}
}
}

也就是说ServiceB.method失败回滚,那么ServiceA.method也会回滚到savepoint点上,ServiceA.method可以选择另外一个分支,比如ServiceC.method,继续执行,来尝试完成自己的事务。但是这个事务并没有在EJB标准中定义。

个人博客
腾讯云社区
掘金
优快云
简书
GitHub
码云
OSCHINA
Segmentfault
公众号:wx.jpg

### Spring事务传播机制详解 在Spring框架中,事务传播机制用于定义多个事务方法相互调用时的事务边界管理方式。这种机制通过`@Transactional(propagation = Propagation.XXX)`注解进行配置,并依赖于数据库的“事务管理器”(如`DataSourceTransactionManager`)实现[^1]。 #### 事务传播机制的核心接口 Spring事务传播机制的基础是`PlatformTransactionManager`和`TransactionDefinition`两个核心接口: - `PlatformTransactionManager`:负责事务的获取、提交和回滚操作。 ```java public interface PlatformTransactionManager { TransactionStatus getTransaction(TransactionDefinition definition); void commit(TransactionStatus status); void rollback(TransactionStatus status); } ``` - `TransactionDefinition`:定义了事务的基本属性,包括传播行为、隔离级别、超时时间以及是否只读等。 ```java public interface TransactionDefinition { int getPropagationBehavior(); int getIsolationLevel(); int getTimeout(); boolean isReadOnly(); } ``` 这些接口共同构成了Spring事务管理的底层支持体系[^2]。 #### 七种事务传播行为及其特性 Spring提供了七种不同的事务传播行为,每种行为适用于特定的业务场景: 1. **PROPAGATION_REQUIRED** 支持当前事务,如果没有事务则创建一个新的事务。这是默认的传播行为,适用于大多数业务场景。 2. **PROPAGATION_SUPPORTS** 支持当前事务,如果没有事务则以非事务方式执行。适用于对事务要求不高的查询操作。 3. **PROPAGATION_MANDATORY** 必须存在当前事务,否则抛出异常。适用于强制要求事务上下文的操作。 4. **PROPAGATION_REQUIRES_NEW** 创建一个新的事务并挂起当前事务。适用于需要独立事务的操作,避免与外部事务产生影响。 5. **PROPAGATION_NOT_SUPPORTED** 以非事务方式执行,如果当前存在事务则将其挂起。适用于不需要事务支持的操作,例如日志记录。 6. **PROPAGATION_NEVER** 以非事务方式进行,如果存在事务则抛出异常。适用于明确禁止事务的场景。 7. **PROPAGATION_NESTED** 如果当前存在事务,则在嵌套事务内执行;如果当前没有事务,则创建一个新事务。适用于需要部分回滚的复杂事务场景[^4]。 #### 事务传播机制的重要性 Spring事务传播机制为复杂业务场景提供了灵活的事务管理能力。通过合理配置传播行为,可以有效控制事务边界,避免数据不一致问题,同时提高系统的性能和稳定性[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值