在前面的篇章里我们已经见识了 Solon 对事务的控制,及其优雅曼妙的形态。该篇将对事务的传播机制做讲解。出于对用户的学习成本考虑,Solon 借签了Spring 的事务传播策略;并友好的支持多数据源事务。

一、为什么要有传播机制?

Solon 的事务是基于 aop 实现的,用者不用关心事务的开始、提交、回滚,只需要在方法上加 @XTran 注解。因为看不到内部情况,所以也会有些疑问:

  • 场景一:方法A调用了方法B,但两个方法都有事务,这个时候如果方法B异常:

    • 是让方法B回滚,还是两个一起回滚?
  • 场景二:方法A调用了方法B,但是只有方法A加了事务:
    • 是否让方法B也加入方法A的事务?
    • 如果方法B异常,是否回滚方法A?
  • 场景三:方法A调用了方法B,两者都有事务,方法B已经正常执行完:
    • 但方法A异常,是否需要回滚方法B的数据?

这个时候事务的传播机制和策略就派上用场了。

二、传播机制生效条件与特点!

基于 aop 来代理事务控制的方案 ,大都是针对于接口或类的之间调用才起效的;所以在同一个类中两个方法之间的调用,传播机制是无效的。了解这一点很重要,不然容易出乌龙事件。

  • 特点1:Solon 的事务传播策略与Spring差不多(出于对新用户的学习成本考虑)
  • 特点2:Solon 可方便的支持多数据源事务
  • 特点3:Solon 可方便支持分库框架或中间件的事务

三、传播机制的策略

下面的类型都是针对于被调用方法来说的,理解起来要想象成两个 service 方法的调用才可以。

传番策略 说明
@XTran(group=true) 如果当前没有事务组,则新建一个事务组;可用于管理多数据源事务,但不会建立链接
@XTran(policy=TranPolicy.required) 如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。这是最常见的选择。也是默认。
@XTran(policy=TranPolicy.requires_new) 新建事务,如果当前存在事务,把当前事务挂起。
@XTran(policy=TranPolicy.nested) 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与required类似的操作。
@XTran(policy=TranPolicy.mandatory) 使用当前的事务,如果当前没有事务,就抛出异常。
@XTran(policy=TranPolicy.supports) 支持当前事务,如果当前没有事务,就以非事务方式执行。
@XTran(policy=TranPolicy.not_supported) 以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
@XTran(policy=TranPolicy.never) 以非事务方式执行,如果当前存在事务,则抛出异常。
  • 补充1:如果当前为事务组,required 和 nested 策略的事务,会自动加入事务组
  • 补充2:group=true 有时候可当 required 用
  • 补充3:一般最常用的是 @XTran(group = true) 和 @Tran 的组合使用

四、XTran 属性说明

属性 说明
value 数据源标识
policy 事务策略
group 是否为事务组;用于管理下属的子事务

五、示例

  • 父回滚,子回滚
@XService
public class UserService{
@XTran
public void addUser(UserModel user){
//....
}
} @XController
public class DemoController{
@XInject
UserService userService; //父回滚,子回滚
//
@XTran(group = true)
@XMapping("/user/add")
pubblic void addUser(UserModel user){
userService.addUser(user);
throw new RuntimeException("不让你加");
} //父回滚,子回滚
//
@XTran
@XMapping("/user/add2")
pubblic void addUser2(UserModel user){
userService.addUser(user);
throw new RuntimeException("不让你加");
}
}
  • 父回滚,子不回滚
@XService
public class UserService{
@XTran(policy = TranPolicy.requires_new)
public void addUser(UserModel user){
//....
}
} @XController
public class DemoController{
@XInject
UserService userService; //父回滚,子不回滚
//
@XTran(group = true)
@XMapping("/user/add")
pubblic void addUser(UserModel user){
userService.addUser(user);
throw new RuntimeException("不让你加;但还是加了:(");
} //父回滚,子不回滚
//
@XTran
@XMapping("/user/add2")
pubblic void addUser2(UserModel user){
userService.addUser(user);
throw new RuntimeException("不让你加;但还是加了:(");
}
}
  • 子回滚父不回滚
@XService
public class UserService{
@XTran(policy = TranPolicy.nested)
public void addUser(UserModel user){
//....
throw new RuntimeException("不让你加");
}
} @XController
public class DemoController{
@XInject
UserService userService; //子回滚父不回滚
//
@XTran(group = true)
@XMapping("/user/add")
pubblic void addUser(UserModel user){
try{
userService.addUser(user);
}catch(ex){ }
} //子回滚父不回滚
//
@XTran
@XMapping("/user/add2")
pubblic void addUser2(UserModel user){
try{
userService.addUser(user);
}catch(ex){ }
}
}
  • 多数据源事务示例
@XService
public class UserService{
@XTran("db1")
public void addUser(UserModel user){
//....
}
} @XService
public class AccountService{
@XTran("db2")
public void addAccount(UserModel user){
//....
}
} @XController
public class DemoController{
@XInject
AccountService accountService; @XInject
UserService userService; @XTran(group = true)
@XMapping("/user/add")
pubblic void addUser(UserModel user){
userService.addUser(user); //会执行db1事务 accountService.addAccount(user); //会执行db2事务
}
}

Solon详解(四)- Solon的事务传播机制的更多相关文章

  1. MySQL系列详解四:MySQL事务-技术流ken

    MySQL 事务 MySQL 事务主要用于处理操作量大,复杂度高的数据.比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数 ...

  2. Springboot mini - Solon详解(四)- Solon的事务传播机制

    Springboot min -Solon 详解系列文章: Springboot mini - Solon详解(一)- 快速入门 Springboot mini - Solon详解(二)- Solon ...

  3. Solon详解(六)- Solon的校验扩展框架使用与扩展

    Solon详解系列文章: Solon详解(一)- 快速入门 Solon详解(二)- Solon的核心 Solon详解(三)- Solon的web开发 Solon详解(四)- Solon的事务传播机制 ...

  4. Solon详解(二)- Solon的核心

    Solon详解系列文章: Solon详解(一)- 快速入门 Solon详解(二)- Solon的核心 Solon详解(三)- Solon的web开发 Solon详解(四)- Solon的事务传播机制 ...

  5. Solon详解(三)- Solon的web开发

    Solon详解系列文章: Solon详解(一)- 快速入门 Solon详解(二)- Solon的核心 Solon详解(三)- Solon的web开发 Solon详解(四)- Solon的事务传播机制 ...

  6. Solon详解(七)- Solon Ioc 的注解对比Spring及JSR330

    Solon详解系列文章: Solon详解(一)- 快速入门 Solon详解(二)- Solon的核心 Solon详解(三)- Solon的web开发 Solon详解(四)- Solon的事务传播机制 ...

  7. Solon详解(八)- Solon的缓存框架使用和定制

    Solon详解系列文章: Solon详解(一)- 快速入门 Solon详解(二)- Solon的核心 Solon详解(三)- Solon的web开发 Solon详解(四)- Solon的事务传播机制 ...

  8. Solon详解(九)- 渲染控制之定制统一的接口输出

    Solon详解系列文章: Solon详解(一)- 快速入门 Solon详解(二)- Solon的核心 Solon详解(三)- Solon的web开发 Solon详解(四)- Solon的事务传播机制 ...

  9. Solon详解(十)- 怎么用 Solon 开发基于 undertow jsp tld 的项目?

    Solon详解系列文章: Solon详解(一)- 快速入门 Solon详解(二)- Solon的核心 Solon详解(三)- Solon的web开发 Solon详解(四)- Solon的事务传播机制 ...

随机推荐

  1. 如何用redis做缓存

    redis缓存 在互联网应用中经常需要用redis来缓存热点数据. redis数据在内存,可以保证数据读取的高效,接近每秒数十万次的吞吐量 减少下层持久层数据库读取压力,像mongodb,每秒近千次读 ...

  2. 以细胞为例 说一下dfs和bfs的思路

    今天发现很少写dfs.. dfs主要思想是递归 bfs主要靠队列 先说一下这个题我被阻了半个小时的地方: 1读数一定要注意scanf的吃回车 2注意数据类型为char,判断时是'0' dfs: #in ...

  3. Blash数组 c++

    //输入一个数作为Blash数组的根, //对于该数组的每一个数x,x*2+1 x*3+1均在该数组 //并且该数组没有其他数字 //该数组升序排列 //输入a,n 输出该数组第n个数 // // # ...

  4. PHP array_udiff() 函数

    实例 比较两个数组的键值(使用用户自定义函数比较键值),并返回差集: <?phpfunction myfunction($a,$b){if ($a===$b){return 0;}return ...

  5. 关于json 是字符串还是对象的问题

    是用ajax提交的时候,json应该是字符串形式: 响应的内容,根据设置处理不同,可能是对象形式:也可能是字符串形式. 如果是字符串形式,可转化成对象形式 再进行处理. 以下常用的几个转换函数:看名字 ...

  6. Taurus.MVC 2.3.4 :WebAPI 文档集成测试功能升级:WebAPI批量自动化测试功能。

    前言: 最近升级了一下Taurus.MVC,现在最新版本是:Taurus.MVC 2.3.4,源码版本和nuget同步. 下面分三个步骤介绍下新版本的WebAPI批量自动化测试功能. 1.启用WebA ...

  7. Spring纯注解配置

    待改造的问题 我们发现,之所以我们现在离不开 xml 配置文件,是因为我们有一句很关键的配置: <!-- 告知spring框架在,读取配置文件,创建容器时,扫描注解,依据注解创建对象,并存入容器 ...

  8. IDEA插件配置推荐

    一.配置 [自动编译]如下图配置:推荐指数[***] [忽略大小写]说明:IDEA默认是匹配大小写,此开关如果未关,你输入字符一定要符合大小写.比如敲string是不会出现代码提示或只能补充.但是如果 ...

  9. 物联网实验Arduino(1)

    回顾 我们使用的平台: Arduino 入门实验1 眨眼睛 /* Blink Turns an LED on for one second, then off for one second, repe ...

  10. 开启CAN通信学习(二)——基于Kvaser的CAN通信案例

    1 案例硬件介绍 Kvaser是瑞典的一家专门提供CAN和LIN总线分析仪及数据记录仪的公司,在CAN产品开发领域已经有近30年的经验,本案例选择的CAN通信硬件型号是Kvaser Leaf Ligh ...