springCloudAlibaba之分布式事务组件---seata

Seata

Sea学习

事务:事务是访问数据库并更新数据库中各项数据的一个程序执行单元。在关系数据库中,一个事务由一组或多组SQL语句组成。事务应该具有4个属性:原子性、一致性、隔离性、持久性。例如更新商品的接口,这就是一个事务,事务是对程序而言的。

  • 原子性:事务是一个不可分割的工作单元,事务中包括的诸多操作要么都做要么都不做。
  • 一致性:保持数据的一致
  • 隔离性:一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的并发执行的各个事务之间不能互相干扰。隔离性又分为四个级别,来保证事务之间的隔离性:读未提交、读已提交、可重复读、串行化(事务串行执行,不会产生并发问题)
  • 持久性:一个事务执行并提交后,就持久到数据库
    本地事务:大多数场景下,我们的应用都只需要操作单一的数据库,这种情况下的事务称之为本地事务。本地事务的ACID特性由数据库直接支持。

分布式事务

两种分布式事务场景:1、同一服务不同数据库;2、同一数据库不同服务;此时都会产生分布式事务的问题。此时用本地数据库事务是无法支持分布式事务的。此时用Seata处理分布式事务问题

Seata

seata的三大角色
在seata的架构中,一共有三个角色:

  • TC:事务协调者
  • TM:事务管理器
  • RM:资源管理器
    管理分支事务处理的资源,与TC交谈以注册分支事务的状态,并驱动分支事务提交或回滚。其中,TC为单独部署的server服务端,TM和RM为嵌入到应用中的client客户端。

二阶段提交协议

常见的分布式事务解决方案:

  • seata阿里分布式事务框架
  • 消息队列
  • saga
  • XA
    他们都有一个共同点,都是遵循二阶段协议(2PC)。两阶段是指完成整个分布式事务,划分成两个步骤完成。
  • 1、准备阶段
  • 在这个阶段,事务的协调者会向所有涉及的数据库或者资源管理器发送准备请求。
  • 每个数据库或者资源管理器收到准备请求后,会执行相应的操作,并且记录准备状态。如果准备成功,就向协调者发送准备就绪的ask。
  • 协调者等待所有参与者都发送准备就绪的信号,如果有任何一个参与者未能准备就绪或者出现了错误,协调者将会发送回滚请求给所有参与者。
  • 提交阶段
  • 如果所有参与者都准备就绪,协调者会向他们发送提交请求。
  • 参与者接收到提交请求后,会正式提交事务,并且释放相关资源。
  • 如果有任何一个参与者未能接收到请求或者出现了错误,协调者将会发送回滚请求给所有参与者。
  • 图例
  • 第一阶段

  • 第二阶段

就像是军训一样,准备阶段:教官让所有同学都立正站好,所有同学都得对齐站好,谁没有站好,全部同学都得重新立正,直到所有同学都准备好,然后,训练阶段:同学们都站一排齐步走,只要有一个没走齐的就重新开始;(👴已经尽力去解释了,我相信即使没有学过计算机的应该也知道这玩意是什么了,嘿嘿);看着是不是毫无压力,

AT模式

  • 一阶段
    befrore image:将要更新的数据查询出来。afer image:事务执行后,将执行完的数据查出来

  • 二阶段

  • 二阶段提交
    因为一阶段已经完成了提交动作,所以二阶段如果没有异常,则直接删除before image、after image、行锁

  • 二阶段回滚
    根据before image拿到逆向sql回滚数据,回滚完成后删除befor image、after image、行锁

相关推荐
天乐敲代码43 分钟前
Etcd静态分布式集群搭建
数据库·分布式·etcd
光纤传感技术研究2 小时前
分布式光纤传感|分布式光纤测温|线型光纤感温火灾探测器DTS|DTS|DAS|BOTDA的行业16年的总结【2024年】
分布式·dts·光纤传感器·botda·光纤传感技术
dbcat官方2 小时前
1.微服务灰度发布(方案设计)
java·数据库·分布式·微服务·中间件·架构
明达技术4 小时前
分布式 IO 模块助力冲压机械臂产线实现智能控制
分布式
溟洵4 小时前
【C++】异步(并发)实现 线程池 ---附源码+实现步骤(future、async、promise、package_task、任务池原理和框架)
服务器·网络·c++·分布式·后端
weisian15118 小时前
Redis篇--常见问题篇7--缓存一致性2(分布式事务框架Seata)
redis·分布式·缓存
不能只会打代码18 小时前
Java并发编程框架之综合案例—— 分布式日志分析系统(七)
java·开发语言·分布式·java并发框架
Elastic 中国社区官方博客18 小时前
如何通过 Kafka 将数据导入 Elasticsearch
大数据·数据库·分布式·elasticsearch·搜索引擎·kafka·全文检索
马剑威(威哥爱编程)19 小时前
分布式Python计算服务MaxFrame使用心得
开发语言·分布式·python·阿里云