【微服务】分布式事务(通过Seata解决分布式事务问题)

embedded/2024/11/26 13:37:42/

分布式事务

分布式事务

分布式系统中,如果一个业务需要多个服务合作完成,而且每一个服务都有事务,多个事务必须同时成功或失败,这样的事务就是分布式事务,其中每个事务就是一个分支事务,整个业务的事务称为全局事务

要解决分布式事务,各个子事务之间必须能感知到彼此的事务状态,才能保证状态一致
我们需要一个事务协调者

Seata

Seata是蚂蚁金服和阿里巴巴共同开源的分布式事务框架解决方案
官方地址:http://seata.io/
Seata事务管理中由三个重要的角色:
TC-事务协调者:维护全局和分支事务的状态,协调全局事务提交或回滚
TM-事务管理器:定义全局事务的范围,开始全局事务,提交或回滚全局事务
RM-资源管理器:管理分支事务,与TC交谈以注册分支事务和报告分支事务的状态

  • 部署TC服务

Seata由于需要记录信息,所以需要数据存储,Seata支持多种存储模式,但考虑到持久化问题,我们一般选择数据库存储
在这里插入图片描述
分别是分支表,分布式,全局表,

然后在虚拟机中通过Docker安装Seata

微服务集成Seata

  1. 在项目中引入Seata依赖:
        <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-seata</artifactId></dependency>
  1. 在application.yml中添加配置,让微服务找到TC服务地址
seata:registry:  #注册中心的配置,微服务根据这些信息去注册中心获取TC服务地址type: nacos #注册中心类型nacos:server-addr: 服务器地址:8848namespace: ""group: DEFAULT_GROUPapplication: seata-server #seata服务名称username: nacospassword: nacostx-service-group: dada #事务组名称service:vgroup-mapping: #事务组与TC集群的映射关系dada: "default"

Seata为用户提供了,AT,TCC,SAGA,XA事务模式进行分布式任务管理

XA模式

XA规范是X/Open组织定义的分布式事务处理(DTP)标准,XA规范,描述了全局的TM与局部的RM之间的接口,几乎所有的主流的数据库都对XA规范提供了支持
在这里插入图片描述
在第一阶段:

  1. RM注册分支事务到TC
  2. RM执行分支业务sql但不提交
  3. RM报告执行状态到TC

在第二阶段:

  1. TC检测各分支事务执行状态
    都成功:通知所有的RM提交事务
    有失败:通知所有的RM回滚事务
  2. RM接收到TC指令,提交或回滚事务
  • 优点

事务的强一致性,满足ACID原则,常用的数据库都支持

  • 缺点

一阶段需要锁定数据库资源,等待二阶段结束才释放,性能较差,依赖关系型数据库实现事务

XA模式使用

1 .修改application.yml文件(每个参与事务的微服务),开启XA模式

seata:data-source-proxy-mode: XA # 开启数据源代理的XA模式
  1. 给发起全局事务的入口方法添加 @GlobalTransactional注解

AT模式

Seata主推的是AT模式,AT模式同样是分阶段提交的事务模型,弥补了XA模型中资源锁定周期过长的缺陷
在这里插入图片描述
阶段一:

  1. 注册分支事务
  2. 记录undo-log(数据快照)
  3. 执行业务sql并提交
  4. 报告事务状态
    阶段二:
    成功:RM删除undo-log
    失败:根据undo-log恢复数据到更新前,进行回滚

AT模式实现

  1. 数据快照需要一张单独的表来存储数据快照(每一个微服务中都需要有一张)
  2. 修改application.yml文件,将事务模式修改为AT模式
seata:data-source-proxy-mode: AT #开启数据源代理的AT模式
  • XA与AT的区别:
  1. XA模式一阶段不提交事务,AT提交
  2. XA模式依赖数据库进行回滚,AT模式利用数据快照实现数据回滚
  3. XA模式强一致,AT模式最终一致

http://www.ppmy.cn/embedded/34064.html

相关文章

亚马逊AWS优秀免费证书分享-云计算从业者(含题库)

亚马逊云AWS官方的程序员专属免费证书又来了&#xff01;这次证书是关于AWS云计算基础概念&#xff0c;以及AWS当下最热门服务如EC2、S3、Lambda、RDS等&#xff0c;强推没有任何AWS背景以及转码的小伙伴去学&#xff01;学完也能变成AWS开发大神&#xff01; 证书名字叫AWS Ed…

SpringMVC的WebMvcConfigurer及返回

由于很久很久没有做过纯springmvc的代码了&#xff0c;好多东西都遗忘&#xff0c;最近接手了一个古早项目springmvc的。记录一下&#xff1a; 1、WebMvcConfigurer 是 Spring Framework 中的一个接口&#xff0c;它提供了一种扩展 Spring MVC 配置的方式。通过实现 WebMvcConf…

【可实战】被测需求理解(需求文档是啥样的、从哪些角度进行需求评审、需求分析需要分析出哪些内容、如何提高需求分析能力)

产品人员会产出一个需求文档&#xff0c;然后组织一个需求的宣讲。测试人员的任务就是在需求宣讲当中&#xff0c;分析需求有没有存在一些问题&#xff0c;然后在需求宣讲结束之后通过分析需求文档&#xff0c;分析里面的测试点并预估一个排期。 一、需求文档是什么样的&#x…

flink 入门学习 wordcount

概述&#xff1a; Apache Flink 是一个流处理和批处理的开源框架&#xff0c;用于处理无界和有界数据流。如果你想要使用 Flink 来统计文本中文字的数量&#xff08;例如&#xff0c;字符数、单词数或行数&#xff09;&#xff0c;你可以通过 Flink 的 DataSet API&#xff08…

linux手动安装es

docker下载 docker pull elasticsearch:7.9.3 docker pull kibana:7.9.3检查安装目录下存在文件夹/data/elasticsearch/data &#xff0c;如果缺少&#xff0c;请创建目录并设置权限&#xff0c;否则会因为无权限访问而启动失败。 # 创建目录 mkdir /data/elasticsearch/data…

ES集群数据备份与迁移

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、文章涉及概念讲解二、操作步骤1.创建 snapshot repository操作主机hadoop1分别操作从机hadoop2和hadoop3 2. 查看仓库信息3. 备份索引&#xff0c;生成快照…

在线协作,开源的设计和原型创作平台:penpot

penpot&#xff1a;面向团队&#xff0c;设计自由- 精选真开源&#xff0c;释放新价值。 概览 Penpot 是一款专为跨职能团队量身定制的开源设计软件&#xff0c;与行业领先的 Figma 齐名&#xff0c;提供了一个强大而灵活的在线设计解决方案。其最大的亮点在于&#xff0c;用户…

Python实战开发及案例分析(6)—— 动态规划

动态规划&#xff08;Dynamic Programming, DP&#xff09;是一种解决复杂问题的算法&#xff0c;它通过将问题分解成较小的子问题&#xff0c;并利用这些子问题的解来有效解决整个问题。动态规划特别适用于具有重叠子问题和最优子结构的问题。 案例分析&#xff1a;斐波那契数…