首先再开传送门(源码地址)

https://github.com/alibaba/fescar

找到server,先看pom.xml文件,引入中最重要的是core的jar,于是打开core的pom.xml,里面除了我们能见到的netty服务,没有其他,于是从这里开始切入:

Fescar分布式全局事务探索——fescar-server源码分析

常量,连接,异常,模型,协议,rpc,由上到下过一遍,首先常量

Fescar分布式全局事务探索——fescar-server源码分析

比较熟悉,file文件那些配置的参数应该就是这些配置

二 连接

先看接口,是个只有put,get,remove3个方法,在看ContextCore,里面定义了个静态常量ContextCore


跟踪load()方法

Fescar分布式全局事务探索——fescar-server源码分析

最终在feacar-commom找到

Fescar分布式全局事务探索——fescar-server源码分析

既然到了comom基础包,我们就先大概看下这个吧(异常,调度,加载,线程)

异常直接看元素类

Fescar分布式全局事务探索——fescar-server源码分析

直接定义了一些常见的错误(出现配置相关错误信息)

再往下深入点,直接看EnhancedServiceLoader

Fescar分布式全局事务探索——fescar-server源码分析

读取文件,并将他按key,value封装到ConcurrentHashMap里面,这些不重要,重要是还是看线程里面的东西吧

Fescar分布式全局事务探索——fescar-server源码分析

线程命名工厂

Fescar分布式全局事务探索——fescar-server源码分析

这2个类相当于再线程上做了切口拦截器

嗯,所有commom包下的类都看了一遍,大致有个了解(为啥我就设计不出来呢,哎,最大缺失就是没有系统化学习!)

不伤感了,继续研究我们的core代码

ContextCoreLoader规定如果在固定位置service.file和fescar.file未找到文件,便在本地线程中读取

Fescar分布式全局事务探索——fescar-server源码分析

接下来看异常元素类

Fescar分布式全局事务探索——fescar-server源码分析

各种全局事务异常,继续看model包

全局事务状态元素类,分支类型,分支状态,全局事务管理接口(准备,提交,回滚,方法),分支资源进出口(OUT提供注册,报告,锁查询;入只提供提交和回滚方法),然后继续协议里看:

都是对各种分支,全局,事务请求,响应的一些类,定义了一个RM和TC的拦截器,最重要是

Fescar分布式全局事务探索——fescar-server源码分析

 

为此还继续等看rpc包内容,先看netty

Fescar分布式全局事务探索——fescar-server源码分析

我愿意花时间继续参考学习netty,但不是这篇文章的目的,所以就简单告诉你创建一个RPC服务,一个RM客户端,一个TM客户端,目前我能看到需要注意的地方是这个

Fescar分布式全局事务探索——fescar-server源码分析

对事务的角色有区分,定义成渠道管理的一个参数属性

总算完了,回到我们的server服务(协调员,锁,session,存储)

先看协调员:

Fescar分布式全局事务探索——fescar-server源码分析

 

借用core代码,对全局事务开始,提交,回滚做了明确的规范,查看默认类

Fescar分布式全局事务探索——fescar-server源码分析

要继续就必须到session来看下全局session怎么来的,先找他的定义

Fescar分布式全局事务探索——fescar-server源码分析

其属性UUID作为事务ID,全局状态作为事务状态,事务组,事务名称,超时时间

并且Global此类继承SessionLifecycle(理解为生命周期类),SessionStorable(字符编码解码类),定义了事务从创建开始到销毁的全过程方法(学到了)

最后来看存储,一个是session存储接口,一个是事务存储接口,都是将他转换file持久化起来(此处逻思路暂时有点模糊只知道大概意思)

继续查看最后一个拦截器

Fescar分布式全局事务探索——fescar-server源码分析

继承了抽象异常拦截器,实现了TC in的拦截器,一个个分开看

Fescar分布式全局事务探索——fescar-server源码分析

成功时回调函数执行,失败时返回异常

看到这里,其实还有很多核心问题没有看到,感觉server服务就类似于一个中间件一样,定义双方交互的协议和获取双方通信信息

下一章有机会机会对TC和RM和TM具体原理进行更深一步的了解!

 

 

 

 

 

 

相关文章:

  • 2021-10-23
  • 2021-05-17
  • 2021-11-12
  • 2021-09-15
  • 2019-02-21
  • 2022-01-17
  • 2021-11-16
  • 2021-09-25
猜你喜欢
  • 2021-10-08
  • 2021-08-23
  • 2021-11-20
  • 2021-10-07
  • 2022-01-05
  • 2021-07-02
  • 2021-09-16
相关资源
相似解决方案