当前位置: 首页 > news >正文

Spring Boot项目整合Seata AT模式

目录

    • 1、添加依赖
    • 2.、配置Seata
    • 3、创建AT模式表
    • 4、使用Seata分布式事务

1、添加依赖

	    <dependency><groupId>io.seata</groupId><artifactId>seata-spring-boot-starter</artifactId></dependency>

上述依赖适用于springboot项目

如果你的项目是springcloud项目,那么可以使用下面这个依赖

        <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-seata</artifactId></dependency>

spring-cloud-starter-alibaba-seata是为Spring Cloud应用程序开发的,可以在Spring Cloud环境中使用,并提供了与Spring Cloud Config、Eureka、Nacos等应用程序所需的集成。它依赖于Spring Cloud Alibaba项目,因此需要引入spring-cloud-starter-alibaba-dependencies的BOM(Bill of Materials),来管理版本依赖关系。

spring-cloud-starter-alibaba-seata推荐依赖配置方式,自定义seata-spring-boot-starter版本

		   <dependency><groupId>io.seata</groupId><artifactId>seata-spring-boot-starter</artifactId><version>最新版</version></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-seata</artifactId><version>最新版本</version><exclusions><exclusion><groupId>io.seata</groupId><artifactId>seata-spring-boot-starter</artifactId></exclusion></exclusions></dependency>

2.、配置Seata

在 Spring Boot 应用的配置文件(application.yml 或 application.properties)中配置 Seata 相关参数,例如:

application.yml

seata:enabled: trueapplication-id: your_application_idtx-service-group: default_tx_groupenable-auto-data-source-proxy: truedata-source-proxy-mode: ATservice:vgroup-mapping:default_tx_group: defaultregistry:type: nacosnacos:server-addr: 127.0.0.1:8848group: SEATA_GROUPnamespace:username: nacospassword: nacosconfig:type: nacosnacos:server-addr: 127.0.0.1:8848group: SEATA_GROUPdata-id: seataServer.propertiesnamespace:username: nacospassword: nacos

上面我seata的注册和配置都放到了nacos上,nacos上的配置可以看我上一篇文章:https://blog.csdn.net/qq_36551991/article/details/135968940

注:data-id要与我们nacos创建的配置文件的data-id一致,这里默认的data-id为seata.properties

对于多个服务来说,都需要配置seata,而且注册中心需要一致

3、创建AT模式表

在AT模式下,每个业务数据库都必须创建 undo_log 表,undo_log 表是 Seata AT模式必须创建的表,主要用于分支事务的回滚

表机构地址:https://github.com/apache/incubator-seata/tree/master/script/client/at/db

大家在上面地址选择自己使用的数据库的sql脚本,进行执行,我的数据库是mysql,所以使用的是mysql.sql

Mysql表结构如下:

CREATE TABLE `undo_log` (`id` bigint(20) NOT NULL AUTO_INCREMENT,`branch_id` bigint(20) NOT NULL,`xid` varchar(100) NOT NULL,`context` varchar(128) NOT NULL,`rollback_info` longblob NOT NULL,`log_status` int(11) NOT NULL,`log_created` datetime NOT NULL,`log_modified` datetime NOT NULL,PRIMARY KEY (`id`),UNIQUE KEY `ux_undo_log` (`xid`,`branch_id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

4、使用Seata分布式事务

在我们的事务方法上添加@GlobalTransactional注解即可开启全局事务,主服务加上@GlobalTransactional注解即可,被调用服务不用加@GlobalTransactional和@Transactional;

下面是一个示例样板:

   //seata全局事务注解@GlobalTransactional (rollbackFor=Exception.class)public void createOrder(Integer userId, Integer productId) {log.info("当前 XID: {}", RootContext.getXID());//1、减库存productFeigne.reduceStock(productId, 1);//2、减余额accountFeign.reduceBalance(userId, product.getPrice());//3、下订单Orders order = new Orders();ordersMapper.insertSelective(order);}
http://www.lryc.cn/news/294918.html

相关文章:

  • 作业2.5
  • LeetCode、790. 多米诺和托米诺平铺【中等,二维DP,可转一维】
  • Python 的 sys 模块常用方法
  • Kafka 使用手册
  • STM32F407移植OpenHarmony笔记7
  • cortexM c语言和汇编嵌套编程
  • 国外传输大文件必选工具
  • Redis渗透SSRF的利用
  • 【深度学习】基于PyTorch架构神经网络学习总结(基础概念基本网络搭建)
  • 专业排版设计软件:QuarkXPress 2024 for mac中文激活版
  • 3593 蓝桥杯 查找最大元素 简单
  • Postgresql数据库存储过程中的事务处理
  • Redis——缓存的持久化
  • kafka-splunk数据通路实践
  • C语言第十九弹---指针(三)
  • TCP/IP LWIP FPGA 笔记
  • 2024年海外优青项目申报指南
  • threejs之常用贴图
  • Unity类银河恶魔城学习记录3-1 EnemyStateMachine源代码 P47
  • 使用webstorm调试vue 2 项目
  • 深度学习缝模块怎么描述创新点?(附写作模板+涨点论文)
  • html,css,js速成
  • 《Docker极简教程》--Docker基础--基础知识(一)
  • Web html和css
  • Three.js学习6:透视相机和正交相机
  • ❤ React18 环境搭建项目与运行(地址已经放Gitee开源)
  • 2024 RTE行业(实时互动行业)人才发展学习总结
  • 92.网游逆向分析与插件开发-游戏窗口化助手-显示游戏数据到小助手UI
  • Stable Diffusion 模型下载:majicMIX fantasy 麦橘幻想
  • docker compose安装minio