acos整合分布式事务框架seata

2023-10-07 22:10

本文主要是介绍acos整合分布式事务框架seata,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

内容摘要

1.nacos:1.1.4版本

2.seata:1.42版本

3.springcloud:H.R1版本

4.seata使用nacos作为配置中心和注册中心

5.示例使用的AT模式

seata官网地址:Seata

最近看了b站尚硅谷的微服务视频,里面用的seata是0.8的老版本,整合方式和现在新版本还是的有点区别,分享下1.42版本的整合方式。示例代码放这:示例代码.zip

1.去官网下载Seata

 

解压后目录如下

 

2.seata配置步骤

2.1打开conf目录下面的file.conf文件,修改存储方式为数据库存储,因为后面用了nacos作为配置中心,这儿其实可以忽略不配置

(注意mysql8.0版本需要高版本驱动,seata默认是低版本,这里直接修改驱动类即可)

 

2.2打开registry.conf

首先修改registry部分,表示将seata服务注册到nacos中去

 

2.3然后修改config部分,表示使用nacos作为配置中心,配置参数全部从nacos中读取

 

2.4打开conf文件中的README-zh.md文件,分别打开client、server、config-center连接,从github中拷贝图中标出的脚本和文件

 

config-center拷贝这俩文件,一个是往nacos写入配置的.sh脚本,另一个是配置项模板文件

 

 

这里注意下config.txt中这个事务组名的配置,可以配置多个,这里就配一个默认的my_test_tx_group作为事务组名

 

接下来是数据库存储配置,配置项和之前file.conf中的改动基本一样

 

2.5将config-serter中的数据导入到nacos中,这儿请参考网上的教程,需要下一个git来运行.sh命令脚本,将模板中的配置项全部导入nacos,成功后如图

 

3.数据库建表

建一个seata的服务端数据库,执行下之前拷贝的建表sql(seata中配置的数据库就连这个)

其他三个库为测试用业务库,每一个库都需要建一个undo_log表

 

3.springboot子模块集成seata

3.1pom.xml的依赖中,seata除了需要springboot、springcloud-alibaba的依赖外,需要如下4个包,其余的如mybatis、jdbc、feign相关依赖这就不说明了

 

3.2 yml中的配置如图

 

 

3.4在事务启动的客户端的server层实现类上,加一个注解@GlobalTransactional,很像springboot中的@Transactional,这里表示是开启全局事务配置

 

4.运行demo程序测试事务

三个测试程序,order订单服务、storage库存服务、accout用户账户服务

正常流程为:创建订单->调用库存服务扣减库存->调用账户服务扣减账户余额→修改订单状态

但如果最后扣除账户余额时服务器报异常!所有操作过的订单、库存和账户数据就会事务回滚,如此来测试下

 

 

先启动三个服务,先看下三个数据库表中的状态:订单为空、账户1000、库存100

 

在调用账户扣除服务之前这给他打个断点,观察下中途数据有没有更改

 

访问测试接口,进入server方法中的断点,这时候看下控制台,事务发起客户端已经打印了Begin new global transaction [192.168.0.107:8091:7088859707401691154],说明全局事务开启了

 

再看看数据库,这时候前面的订单、库存操作已经执行了

 

接下来放开断点,调用账户服务扣款并抛运行时异常,看看客户端控制台,已经打印事务回滚了

 

再看看数据库,数据已经回滚成功,到这就说明AT模式分布式事务配置成功了

 

这篇关于acos整合分布式事务框架seata的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/160736

相关文章

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

ZooKeeper 中的 Curator 框架解析

Apache ZooKeeper 是一个为分布式应用提供一致性服务的软件。它提供了诸如配置管理、分布式同步、组服务等功能。在使用 ZooKeeper 时,Curator 是一个非常流行的客户端库,它简化了 ZooKeeper 的使用,提供了高级的抽象和丰富的工具。本文将详细介绍 Curator 框架,包括它的设计哲学、核心组件以及如何使用 Curator 来简化 ZooKeeper 的操作。 1

集中式版本控制与分布式版本控制——Git 学习笔记01

什么是版本控制 如果你用 Microsoft Word 写过东西,那你八成会有这样的经历: 想删除一段文字,又怕将来这段文字有用,怎么办呢?有一个办法,先把当前文件“另存为”一个文件,然后继续改,改到某个程度,再“另存为”一个文件。就这样改着、存着……最后你的 Word 文档变成了这样: 过了几天,你想找回被删除的文字,但是已经记不清保存在哪个文件了,只能挨个去找。真麻烦,眼睛都花了。看

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟

Spring Framework系统框架

序号表示的是学习顺序 IoC(控制反转)/DI(依赖注入): ioc:思想上是控制反转,spring提供了一个容器,称为IOC容器,用它来充当IOC思想中的外部。 我的理解就是spring把这些对象集中管理,放在容器中,这个容器就叫Ioc这些对象统称为Bean 用对象的时候不用new,直接外部提供(bean) 当外部的对象有关系的时候,IOC给它俩绑好(DI) DI和IO

MySql 事务练习

事务(transaction) -- 事务 transaction-- 事务是一组操作的集合,是一个不可分割的工作单位,事务会将所有的操作作为一个整体一起向系统提交或撤销请求-- 事务的操作要么同时成功,要么同时失败-- MySql的事务默认是自动提交的,当执行一个DML语句,MySql会立即自动隐式提交事务-- 常见案例:银行转账-- 逻辑:A给B转账1000:1.查询

开源分布式数据库中间件

转自:https://www.csdn.net/article/2015-07-16/2825228 MyCat:开源分布式数据库中间件 为什么需要MyCat? 虽然云计算时代,传统数据库存在着先天性的弊端,但是NoSQL数据库又无法将其替代。如果传统数据易于扩展,可切分,就可以避免单机(单库)的性能缺陷。 MyCat的目标就是:低成本地将现有的单机数据库和应用平滑迁移到“云”端

RabbitMQ使用及与spring boot整合

1.MQ   消息队列(Message Queue,简称MQ)——应用程序和应用程序之间的通信方法   应用:不同进程Process/线程Thread之间通信   比较流行的中间件:     ActiveMQ     RabbitMQ(非常重量级,更适合于企业级的开发)     Kafka(高吞吐量的分布式发布订阅消息系统)     RocketMQ   在高并发、可靠性、成熟度等