目录
百战程序员,全站22050+开发课程+文档 ,学习精选优质好课快人一步!观看视频 快捷键ALT+N

JAVA全系列 教程

3762个小节阅读:7088.1k

收藏
全部开发者教程

C语言快速入门

JAVA全系列 教程

面向对象的程序设计语言

Python全系列 教程

Python3.x版本,未来主流的版本

人工智能 教程

顺势而为,AI创新未来

大厂算法 教程

算法,程序员自我提升必经之路

C++ 教程

一门通用计算机编程语言

微服务 教程

目前业界流行的框架组合

web前端全系列 教程

通向WEB技术世界的钥匙

大数据全系列 教程

站在云端操控万千数据

AIGC全能工具班

A

A A

White Night

阅读(884)
赞(0)

Seata提供XA模式实现分布式事务_项目引入Seata

image-20220330160432306

Seata实现XA要点

  • 1、全局事务开始使用GlobalTransactional标识。
  • 2、每个本地事务方案仍然使用@Transactional标识。
  • 3、每个数据都需要创建undo_log表,此表是Seata保证本地事务一致性的关键。

image-20220330160542557

创建 UNDO_LOG 表

SEATA XA 模式需要 UNDO_LOG

添加依赖

修改配置文件YML

bank1微服务开启全局事物

image-20220316160449746

注意:

将@GlobalTransactional注解标注在全局事务发起的Service实现方法上,开启全局事务 :GlobalTransactionalInterceptor会拦截@GlobalTransactional注解的方法,生成全局事务ID(XID),XID会在整个分布式事务中传递。 在远程调用时,spring-cloud-alibaba-seata会拦截Feign调用将XID传递到下游服务。

bank2开启事物

image-20220316160547054

测试分布式事物

发送请求http://localhost:6001/transfer?amount=2

image-20220316160646179

总结

传统2PC(基于数据库XA协议)和Seata实现2PC的两种2PC方案,由于Seata的零入侵并且解决了传统2PC长期锁资源的问题,所以推荐采用Seata实现2PC。

实时效果反馈

1.Seata技术中如何开启全局事物_____。

A Global标识

B GlobalTransactional标识

C Transactional标识

D 以上都错误

2.Seata技术中如何开启本地事物____。

A Global标识

B GlobalTransactional标识

C Transactional标识

D 以上都错误

答案

1=>B 2=>C

北京市昌平区回龙观镇南店村综合商业楼2楼226室

©2014-2023 百战卓越(北京)科技有限公司 All Rights Reserved.

京ICP备14032124号-2