碧桂园旺生活平台强一致性分布式事务,是基于二阶段提交+本地事务补偿机制来实现。原理介绍
基于java语言来开发(JDK1.8),事务发起者,参与者与协调者底层基于netty长连接通信. 支持dubbo,springcloud进行分布式事务。
因为文件名太长,大家在拉取代码的时候执git命令:git config core.longpaths true
-
事务角色
-
事务发起者(可理解为消费者 如:dubbo的消费者,springcloud的调用方),发起分布式事务
-
事务参与者(可理解为提供者 如:dubbo的提供者,springcloud的rest服务提供者),参与事务发起者的事务
-
事务协调者(tx-manager),协调分布式事务的提交,回滚等。
-
技术方案
-
协调者(tx-manager)采用eureka作为注册中心,集群配置,达到服务的高可用,采用redis集群来分布式存储事务数据, springboot 提供rest服务,采用netty与参与者,发起者进行长连接通信。
-
发起者与协调者,采用Aspect AOP 切面思想,SPI,多线程,异步回调,线程池,netty通信等技术。
-
-
SPI扩展
- 本地事务恢复,支持redis,mogondb,zookeeper,file,mysql等关系型数据库
- 本地事务序列化保存,支持java,hessian,kryo,protostuff
- netty通信序列化方式,支持 hessian,kryo,protostuff