Seata学习

编程入门 行业动态 更新时间:2024-10-19 08:52:18

<a href=https://www.elefans.com/category/jswz/34/1747733.html style=Seata学习"/>

Seata学习

Seata

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

官网地址:.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过程,使其做到更高的性能。

更多推荐

Seata学习

本文发布于:2023-12-05 02:19:37,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1662762.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:Seata

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!