• Seata学习


    Seata

    Seata 是一款开源的分布式事务解决方案,致力于在微服务架构下提供高性能和简单易用的分布式事务服务。

    官网地址:https://seata.io/zh-cn/index.html

    为什么会产生分布式事务?

    在这里插入图片描述

    示例:用户下单后需要创建订单,同时会员积分对应增加,库存数量相应减少。如果是在一个数据库单个事务中没有问题。一旦涉及分布式环境下,需要保证所有的数据要么全局提交,要么全局回滚。

    分布式解决方案需要增加一个事务协调者。

    二阶段提交:

    第一个阶段如下:

    在这里插入图片描述

    第二个阶段如下:

    在这里插入图片描述

    分布式事务体系三个重要角色

    • 事务管理器(TM):决定什么时候全局提交/回滚 (司令官)
    • 事务协调者(TC):负责通知命令的中间件Seata-Server(传令官)
    • 资源管理器(RM):做具体事儿的工具人(大头兵)

    在这里插入图片描述

    事务边界

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    操作成功,全局提交;操作出现异常,全局回滚。

    在这里插入图片描述

    Seata AT模式下如何实现数据自动提交、回滚?

    通过SQL Parser对SQL语句进行解析实现UNDO_LOG。

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    Seata如何避免并发场景的脏读与脏写?

    利用TC自带的分布式锁

    在这里插入图片描述

    怎么使用Seata框架,来保证事务的隔离性?

    因seata一阶段本地事务已提交,为防止其他事务脏读脏写需要加强隔离。

    1. 脏读 select语句加for update,代理方法增加@GlobalLock+@Transactional或@GlobalTransactional
    2. 脏写必须使用@GlobalTransactional

    注:如果你查询的业务的接口没有@GlobalTransactional 包裹,也就是这个方法上压根没有分布式事务的需求,这时你可以在方法上标注@GlobalLock+@Transactional 注解,并且在查询语句上加 for update。 如果你查询的接口在事务链路上外层有@GlobalTransactional注解,那么你查询的语句只要加for update就行。设计这个注解的原因是在没有这个注解之前,需要查询分布式事务读已提交的数据,但业务本身不需要分布式事务。 若使用@GlobalTransactional注解就会增加一些没用的额外的rpc开销比如begin 返回xid,提交事务等。GlobalLock简化了rpc过程,使其做到更高的性能。

  • 相关阅读:
    数组和对象的扩展运算符
    从零开始学YC-Framework之鉴权
    Python爬虫-使用代理伪装IP
    【LeetCode算法系列题解】第76~80题
    贼全! 一举通关的 Spring+SpringBoot+SpringCloud 全攻略, 是真香啊
    vue路由获取菜单名称和路由跳转传参
    三、C语言常用运算符
    汉字转拼音
    ti am335 RT-LINUX测试
    Spring Cloud(八):Spring Cloud Alibaba Seata 2PC、AT、XA、TCC
  • 原文地址:https://blog.csdn.net/liwenyang1992/article/details/133979621