前言
使用seata,以目前最新的坐标版本来看
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-seata</artifactId>
<version>2021.1</version>
</dependency>
data:image/s3,"s3://crabby-images/98eb9/98eb98128c481b7442a6b70622a3eb24af1ee524" alt=""
其内部seata相关的依赖仅为seata-spring-boot-starter,可知其是整体功能的起始点
以seata目前最新的发布版本1.4.2来分析下的源码:GitHub
模块介绍
data:image/s3,"s3://crabby-images/8d926/8d92630f8e01cf2875f8f0c9e0f2bdb7d7d7410e" alt=""
分为两部分:
- seata-server:事务协调器(TC),独立进程执行
- seata-spring:spring体系下相关使用模块(此篇讲解部分)
配置
模块对应的目录结构如下
data:image/s3,"s3://crabby-images/0babd/0babdd6fa9dbcc0fea278be10e81b4c63bee93b0" alt=""
可见spring.factories
data:image/s3,"s3://crabby-images/5b929/5b929c8347d91a088e234f3574e7e7f1e8f3b836" alt=""
- SeataPropertiesAutoConfiguration 初始化默认配置参数
- SeataDataSourceAutoConfiguration 处理datasource(两个方面:BeanPostProcessor、ProxyCreator)
- SeataAutoConfiguration 全局事务扫描及设置
- HttpAutoConfiguration 配置拦截器及异常处理器WebMvcConfigurerAdapter
重点关注SeataAutoConfiguration
data:image/s3,"s3://crabby-images/6c9fe/6c9fe381958c6c2ec20d226410934c469c529726" alt=""
-
DefaultFailureHandlerImpl 失败处理
-
GlobalTransactionScanner 事务扫描器
扫描
data:image/s3,"s3://crabby-images/3b593/3b593d55fe817ef729bdd327095f3afb4c98fcfd" alt=""
GlobalTransactionScanner继承自AbstractAutoProxyCreator
AbstractAutoProxyCreator:自动代理生成器,为符合条件的bean设置代理
data:image/s3,"s3://crabby-images/6eae5/6eae5911243586c4f246220d3c6ca6d46ac7440f" alt=""
data:image/s3,"s3://crabby-images/565c6/565c629d431815ff5f987ba3047b8fabd7099252" alt=""
data:image/s3,"s3://crabby-images/e9201/e92013c4a9a965cdae84f3e257c479149fd49580" alt=""
至此含有注解(TwoPhaseBusinessAction、GlobalTransactional、GlobalLock)的bean就被设置了拦截器
拦截器
GlobalTransactionalInterceptor
data:image/s3,"s3://crabby-images/463af/463af2e401a228666ea56557f7b8ba33eae373ab" alt=""
data:image/s3,"s3://crabby-images/eefe0/eefe0c032d447111f7c081699ec1e168c3fbaf18" alt=""
方法触发时拦截对应的执行信息(GlobalTransactional、GlobalLock注解情况),根据注解类型不同进行不同的逻辑处理
以GlobalTransactional类型为例
data:image/s3,"s3://crabby-images/4a94d/4a94d325c74008cf3ef67dea57ccd1fc29c7072b" alt=""
采用的是:设计模式行为型-命令模式
主要任务:对执行的方法子事务进行管理
data:image/s3,"s3://crabby-images/b968a/b968a197490d2929d0efc3967e51b0997ad674a3" alt=""
详见TransactionalTemplate.execute
TccActionInterceptor
同GlobalTransactionalInterceptor触发模式
data:image/s3,"s3://crabby-images/45d08/45d08cb52ecadd43f617261ec42fdd9dfc6ab507" alt=""
事务具体的执行交由ActionInterceptorHandler进行处理
类关系图
data:image/s3,"s3://crabby-images/e8d81/e8d8115228f1c5a7d360724dcf60bf2605232c63" alt=""
网友评论