Seata集成Mybatis-Plus解决多数据源事务问题

 更新时间:2023年11月01日 14:39:41   作者:吴名氏.  
当进行业务操作时,订单发生异常 ,进行了回滚操作,因为在不同的数据库实例中,余额却扣除成功,此时发现数据不一致问题,本文给大家介绍Seata集成Mybatis-Plus解决多数据源事务问题,感兴趣的朋友一起看看吧

1 前言

在使用单个服务,多数据源时,也存在分布式事务问题。

当单体系统需要访问多个数据库(实例)时就会产生分布式事务。 比如:用户信 息和订单信息分别在两个MySQL实例存储,用户管理系统删除用户信息,需要分别删除用户信息及用户的订单信 息,由于数据分布在不同的数据实例,需要通过不同的数据库链接去操作数据,此时产生分布式事务。 简言之:跨数据库实例产生分布式事务。

在这里插入图片描述

2 问题场景

参考此文档搭建一个多数据源项目Mybatis-Plus入门系列(19) -多数据源使用详解。

在插入订单数据时,模拟一个异常:

    @Override
    @DS("db_order")
    @Transactional
    public void insertOrder() {
        // 插入订单
        OrderTbl orderTbl = new OrderTbl();
        orderTbl.setUserId("12");
        orderTbl.setCommodityCode("IPHONE 13");
        orderTbl.setCount(1);
        orderTblMapper.insert(orderTbl);
        int i = 5 / 0;
    }

当进行业务操作时,订单发生异常 ,进行了回滚操作,因为在不同的数据库实例中,余额却扣除成功,此时发现数据不一致问题。

3 使用Seata 解决多数据源事务问题

3.1 集成Nacos Seata

参考该系列,给当前服务添加Nacos Seata 相关依赖,并启动Nacos Seata 。

3.2 多数据源集成Seata

多数据源集成Seata 时,主要是需要修改一下几个配置即可。

多数据源中,开启分布式事务,设置事务模式:

  datasource:
    # 多数据源
    dynamic:
      # 省略其他 
      # 开启分布式事务
      seata: true
      # 事务模式 为AT
      seata-mode: AT

seata 中,关闭数据源自动代理

seata:
  # 是否开启spring-boot自动装配,默认true,包括数据源的自动代理以及GlobalTransactionScanner初始化
  enabled: true
  # 是否开启数据源自动代理,默认开启
  enable-auto-data-source-proxy: false

3.3 测试

添加@GlobalTransactional注解。

    @GlobalTransactional
    @GetMapping("/test")
    public Object test() throws InterruptedException {
        accountTblService.reduceMoney();
        orderTblService.insertOrder();
        return "执行完毕!";
    }

测试发现,异常时,余额和订单服务都进行了回滚,集成成功。

到此这篇关于Seata集成Mybatis-Plus多数据源的文章就介绍到这了,更多相关Seata集成Mybatis-Plus多数据源内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 轻松掌握java中介者模式

    轻松掌握java中介者模式

    这篇文章主要帮助大家轻松掌握java中介者模式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 基于SpringBoot+jQuery实现留言板功能

    基于SpringBoot+jQuery实现留言板功能

    本教程详细介绍了如何使用Spring Boot 3.x和jQuery实现一个完整的留言板系统,主要功能包括留言查看、提交、实时刷新和表单校验,感兴趣的可以了解一下
    2026-01-01
  • Spring实现动态修改时间参数并手动开启关停操作

    Spring实现动态修改时间参数并手动开启关停操作

    spring实现定时任务的方式有三种,分别是java自带的timer类、spring task和quartz三种。本文只介绍spring自带的task和第三方quartz,感兴趣的朋友参考下吧
    2017-09-09
  • Java中volatile关键字的作用与用法详解

    Java中volatile关键字的作用与用法详解

    volatile关键字虽然从字面上理解起来比较简单,但是要用好不是一件容易的事情。这篇文章主要介绍了Java中volatile关键字的作用与用法详解的相关资料,需要的朋友可以参考下
    2016-09-09
  • Java常问面试内容--数组、声明、初始化、冒泡、多维数组、稀疏数组

    Java常问面试内容--数组、声明、初始化、冒泡、多维数组、稀疏数组

    这篇文章主要介绍了Java多线程面试题(面试官常问),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-07-07
  • Spring Security自定义身份认证的实现方法

    Spring Security自定义身份认证的实现方法

    这篇文章主要介绍了Spring Security自定义身份认证的实现方法,下面对Spring Security的这三种自定义身份认证进行详细讲解,需要的朋友可以参考下
    2025-04-04
  • 新手学习JQuery基本操作和使用案例解析

    新手学习JQuery基本操作和使用案例解析

    这篇文章主要介绍了新手学习JQuery基本操作和使用案例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • MyBatis深入解读懒加载的实现

    MyBatis深入解读懒加载的实现

    顾名思义,懒加载就是因为偷懒了,懒得加载了,只有使用的时候才进行加载。其实,懒加载也加延迟加载,主要以应用与Mybatis的关联查询,按照设置的延迟规则,推迟对延迟对关联对象的select查询
    2022-04-04
  • java + dom4j.jar提取xml文档内容

    java + dom4j.jar提取xml文档内容

    这篇文章主要为大家详细介绍了java + dom4j.jar提取xml文档内容,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • Spring Boot中@Autowired注入为空的原因以及解决方法

    Spring Boot中@Autowired注入为空的原因以及解决方法

    最近在开发中遇到了使用@Autowired注解自动装配时会报空指针,发现对象并没有装配进来,下面这篇文章主要给大家介绍了关于Spring Boot中@Autowired注入为空的原因以及解决方法,需要的朋友可以参考下
    2024-01-01

最新评论