介绍
Seata 是阿里巴巴开源的分布式事务中间件,一种分布式事务解决方案,具有高性能和易于使用的微服务架构。
对业务无侵入:即减少技术架构上的微服务化所带来的分布式事务问题对业务的侵入
高性能:减少分布式事务解决方案所带来的性能消耗
分布式事务是一个全局事务,由一批分支事务组成,通常分支事务只是本地事务。
设计
Seata中有两种分布式事务实现方案,AT和TCC。
AT
AT模式是基于XA事务演进而来,核心是对业务无侵入,是一种改进后的两阶段提交,需要数据库支持。
基本组件:
事务协调器(TC):事务协调器,维护全局事务的运行状态,负责协调并驱动全局事务的提交或回滚。
Transaction Manager(TM): 控制全局事务的边界,负责开启一个全局事务,并最终发起全局提交或全局回滚的决议。
资源管理器(RM):控制分支事务,负责分支注册、状态汇报,并接收事务协调器的指令,驱动分支(本地)事务的提交和回滚。
处理流程:
TM要求TC开始新的全局事务。TC生成表示全局事务的XID。
XID通过微服务的调用链传播。
RM将本地事务注册为XID到TC的相应全局事务的分支。
TM要求TC提交或回滚XID的相应全局事务。
TC在XID的相应全局事务下驱动所有分支事务以完成分支提交或回滚。
TCC
Seata要求每个接口实现prepare、commit、rollback。
与 AT 模式一样,在运行时,该切面会拦截所有对 TCC 接口的调用。每调用一次 Try 接口,切面会先向 TC 注册一个分支事务,然后才去执行原来的 RPC 调用。当请求链路调用完成后,TC 通过分支事务的资源 ID 回调到正确的参与者去执行对应 TCC 资源的 Confirm 或 Cancel 方法。
初步操作 Try:完成所有业务检查,预留必须的业务资源。
确认操作 Confirm:真正执行的业务逻辑,不做任何业务检查,只使用 Try 阶段预留的业务资源。因此,只要 Try 操作成功,Confirm 必须能成功。另外,Confirm 操作需满足幂等性,保证一笔分布式事务能且只能成功一次。
取消操作 Cancel:释放 Try 阶段预留的业务资源。同样的,Cancel 操作也需要满足幂等性。
Seata Server安装
1.下载最新版本的Seata切断https://github.com/seata/seata/releases
2。解压并启动Seata服务器
<代码>解压Seata——xxx。zip
cd分布
/bin/seata - sh。sh文件代码>
<强>示例强>
<>强场景:强>
把数据库0 A中代理表的一条数据转移到数据库zerob中代理表里面。
<强>模块:强>
zero-discovery-server:注册中心
zero-gateway-server:服务网关
zero-consumer:服务消费者
zero-provider-a:服务提供者
zero-provider-b:服务提供者B
<>强架构及版本:强>
Spring-cloud:芬奇利。BUILD-SNAPSHOT
spring-cloud-starter-netflix-eureka-server: 2.0.4。BUILD-SNAPSHOT
spring-cloud-starter-netflix-eureka-client: 2.0.4。BUILD-SNAPSHOT
spring-cloud-starter-gateway: 2.0.4。BUILD-SNAPSHOT
spring-cloud-starter-openfeign: 2.0.0。发布
spring-boot: 2.0.0。发布
spring-boot-starter-data-jpa: 2.0.0。发布
spring-cloud-alibaba-seata: 0.9.1。BUILD-SNAPSHOT
seata-all: 0.6.1
mysql-connector-java: 8.0.11
druid-spring-boot-starter: 1.1.18
mysql: 5.7