飙血推荐
  • HTML教程
  • MySQL教程
  • JavaScript基础教程
  • php入门教程
  • JavaScript正则表达式运用
  • Excel函数教程
  • UEditor使用文档
  • AngularJS教程
  • ThinkPHP5.0教程

分布式事务框架-Litx补偿事务框架源码解析

时间:2022-02-11  作者:zdd-java  

前言

  之前某段时间在研究分布式事务过程中,对实现原理比较好奇,于是去Gitee上找了几个人气比较高的框架进行学习,其中印象深刻的有Litx,因为Litx源码不多,且都是基于Spring和Dubbo底层实现,所以理解起来比较容易,索性对这个框架分析过长进行总结如下

litx(https://域名/bryan31/litx)是一个基于补偿的轻量级分布式事务框架。(目前只支持dubbo,未来计划支持http等其他rpc调用的补偿)

  • 对代码逻辑无侵入
  • 和spring事务无缝结合(内部实现是集成spring的事务管理器,靠@transactional标注开启)
  • 自动回滚补偿接口
  • 如回滚异常提供hook接口可供扩展,当回滚失败时,可以拿到数据自行可作处理。

 首先看源码得先把项目拉到本地,通过跑demo或者测试用例方式先让项目正常运行,然后结合文档+观察输出日志+debug方式找到其入口,然后深入对每个方法进行深挖

  如下是项目结构图,从上到下分别是 litx-core(存放核心模块)、litx-dubbo(实现dubbo分布式事务)、litx-test(测试用例)

   该框架其主要核心思路是基于Spring->BeanPostProcessor + 自定义分布式事务标识注解 + Dubbo Filter + 重写DataSourceTransactionManager实现分布式事务,由于篇幅有限,下面只对核心的代码进行分析

域名-dubbo

  •  LitxDubboDefinationScanner(注册每个方法对应的回滚方法到Map)

  •  回滚方法注册逻辑

域名-dubbo

 

域名-core

 

 以上图片篇幅就是Litx分布式事务源码的核心

标签:编程
湘ICP备14001474号-3  投诉建议:234161800@qq.com   部分内容来源于网络,如有侵权,请联系删除。