码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • seata的AT模式分析


    Seata AT模式是最早⽀持的模式。AT模式是指Automatic (Branch)Transaction Mode⾃动化分⽀事务。

    (1)AT模式的核心组件:

    • 事务协调器 TC

    维护全局和分支事务的状态;

    维护全局锁的状态;

    接受TM的提交或者回滚命令,联系RM进行分支事务的提交或者回滚。

    • 事务管理者 TM

    开启全局事务,向TC申请全局事务ID;

    根据TC反馈的分支事务结果来决定提交或者回滚;

    告诉TC提交或者回滚一个全局事务;

    • 资源管理者 RM

    管理执行分支事务的那些资源;

    向TC注册分支事务、上报分支事务状态、控制分支事务的提交或者回滚;

    (2)事务流程:

    • TM 请求 TC,开始一个新的全局事务,TC 会为这个全局事务生成一个 XID。
    • TM所属的业务把XID 通过微服务的调用链传递到其他微服务。
    • 各微服务的RM 把本地事务作为这个XID的分支事务注册到TC。
    • RM把本地事务的事务前image和事务后image记录到undo_log,同时向TC申请变更行的全局锁,开始进行事务提交,并且把本地分枝事务的结果反馈给TC。
    • TM收到TC通知的各分支事务结果,决定提交或者回滚,TM 请求 TC 对这个 XID 进行提交或回滚。
    • TC 指挥这个 XID 下面的所有分支事务进行提交、回滚。提交则是去掉阶段1的各分支事务对应的全局锁,并且删除undo_log;回滚则是根据阶段1对应的分支事务的undo_log记录的事务前image来回滚数据,在回滚前要判定数据和阶段1的事务后image的数据一致性,一致则回滚,不一致则要有策略或者人工来介入。

    (3)典型问题:

    如果回滚的时候,进行数据核验的时候,发现数据被其他应用修改了,该怎么办?

    at是要保证所有操作数据库的动作都在seata事务的全局事务覆盖下。也就是说,如果你这个库的这个表被其他应用用了,让这个应用也集成seata就行了。

  • 相关阅读:
    【机器学习基础】K-Means聚类算法
    页面功能并不是所有用户都能执行 点击判断用户权限路由是否进行跳转
    Java中的Map接口(Hashtable+LinkedHashMap)[77]
    scrapy框架-Middleware(爬虫中间件)
    Meta-Transformer:基于Transformer的多模态感知,融合Token化与共享编码
    面试题:说说你了解的分布式 ID 生成方案
    生命在于学习——代码审计工具
    TS中export与import的用法,和Java的区别
    16位、32位、64位系统字节长度
    手记系列之二 ----- 关于IDEA的一些使用方法经验
  • 原文地址:https://blog.csdn.net/zhangzhaokun/article/details/133935447
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号