sptingboot 整合 seata1.6.1 (XA模式)

文章介绍了如何在SpringBoot应用中整合Seata1.6.1,利用AT模式进行分布式事务处理。通过修改数据源代理为支持XA协议的DataSourceProxyXA,并配置Seata的Nacos服务发现和配置中心,确保事务的可回滚性和持久化。在实战部分,通过示例展示了正常和异常下单场景,演示了分布式事务的回滚机制。
摘要由CSDN通过智能技术生成

接:sptingboot 整合 seata1.6.1 (AT模式)

简介 官方简介

在 Seata 定义的分布式事务框架内,利用事务资源(数据库、消息服务等)对 XA 协议的支持,以 XA 协议的机制来管理分支事务的一种 事务模式

  • 执行阶段:

    • 可回滚:业务 SQL 操作放在 XA 分支中进行,由资源对 XA 协议的支持来保证 可回滚
    • 持久化:XA 分支完成后,执行 XA prepare,同样,由资源对 XA 协议的支持来保证 持久化(即,之后任何意外都不会造成无法回滚的情况)
  • 完成阶段:

  • 分支提交:执行 XA 分支的 commit

  • 分支回滚:执行 XA 分支的 rollback

实战

    @Primary //设置⾸选数据源对象
    @Bean("dataSource")
    public DataSourceProxyXA dataSource(DataSource druidDataSource) {
//        return new DataSourceProxy(druidDataSource);
        return new DataSourceProxyXA(druidDataSource);
    }
  • common-db 的.ymal配置application-seata.yml
# staet----------------------------seata服务配置
seata:
  # 切换XA模式
  enable: true
  data-source-proxy-mode: XA
  enable-auto-data-source-proxy: true
  config:
    type: nacos
    nacos:
      server-addr: 127.0.0.1:8848
      namespace: seata-server
      group: SEATA_GROUP
      username: nacos
      password: nacos
  registry:
    type: nacos
    nacos:
      server-addr: 127.0.0.1:8848
      namespace: seata-server
      application: seata-server
      group: SEATA_GROUP
      username: nacos
      password: nacos
  service:
    vgroup-mapping:
      default_tx_group: default
    disable-global-transaction: false
    grouplist:
      default: 127.0.0.1:8091
  tx-service-group: default_tx_group
spring:
  cloud:
    alibaba:
      seata:
        tx-service-group: default_tx_group
logging:
  level:
    seata: debug

在这里插入图片描述

  • 验证

库存为100,下单超过100即可触发分布式事务回滚。
http://localhost:8000/test1 正常下单,加积分,减库存。(每下1单数量10个,积分加10,库存-10)
http://localhost:8000/test2 异常下单,库存不足,回滚订单和积分。

  • http://localhost:8000/test1 正常下单,加积分,减库存。
    在这里插入图片描述

  • http://localhost:8000/test2 异常下单,库存不足,回滚订单和积分。
    在这里插入图片描述

下面是一个使用FeignClient调用TCC模式分布式事务的示例: 1. 首先,在pom.xml文件中添加Feign和Seata的依赖: ```xml <dependencies> <!-- Seata --> <dependency> <groupId>io.seata</groupId> <artifactId>seata-all</artifactId> <version>1.6.1</version> </dependency> <!-- Feign --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> <version>2.2.2.RELEASE</version> </dependency> </dependencies> ``` 2. 在启动类上添加@EnableFeignClients注解启用FeignClient: ```java @SpringBootApplication @EnableFeignClients public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 3. 创建FeignClient接口,并使用@LocalTCC注解标记TCC模式下的方法: ```java @FeignClient(name = "order-service") public interface OrderServiceClient { @RequestMapping(value = "/order/create", method = RequestMethod.POST) @LocalTCC Boolean createOrder(Order order); } ``` 4. 在业务逻辑中调用FeignClient: ```java @Service public class BusinessService { @Autowired private OrderServiceClient orderServiceClient; @GlobalTransactional public void createOrder(Order order) { orderServiceClient.createOrder(order); } } ``` 在上述代码中,@GlobalTransactional注解表示开启了一个全局事务,如果业务逻辑执行失败,Seata框架会回滚之前的所有操作。同时,业务逻辑中调用了FeignClient的createOrder方法,该方法被@LocalTCC注解标记,表示使用TCC模式处理分布式事务。 上述示例中的OrderServiceClient是一个FeignClient接口,其调用的服务名为order-service,对应的服务需要在Seata中注册为一个TC服务,同时需要在该服务的配置文件中添加Seata的相关配置,以支持TCC模式下的分布式事务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

刚仔灬

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值