Spring进阶:3步引入MybatisPlus多数据源,详细配置及原理解析

news/2025/2/12 16:36:46/

前言

MybatisPlus(MP)作为mybatis的增强工具,提供了配置多数据源的扩展,通过简单的几步配置,即可使用注解轻松切换数据源。

以下是dynamic-datasource提供的功能列表:

使用方法

1,引入dynamic-datasource-spring-boot-starter。

<dependency><groupId>com.baomidou</groupId><artifactId>dynamic-datasource-spring-boot-starter</artifactId><version>${version}</version>
</dependency>

2,配置多数据源。

spring:datasource:dynamic:primary: master #默认主库名为masterstrict: false #不使用严格模式datasource:master:url: jdbc:mysql://127.0.0.1:3306/masterusername: rootpassword: 66668888driver-class-name: com.mysql.jdbc.Driver slave_1:url: jdbc:mysql://127.0.0.1:3307/slave_1username: rootpassword: 66668888driver-class-name: com.mysql.jdbc.Driverslave_2:url: ENC(xxxxx) # 内置加密username: ENC(xxxxx)password: ENC(xxxxx)driver-class-name: com.mysql.jdbc.Driver

主库默认为master,从库命名的格式默认以_分割。

3,在方法或者类上使用@DS切换数据源

DS注解既可以写在类上,也可以写在方法上,方法上的优先级高于类。

如果没有指定DS的属性值或者没有使用DS注解,就自动走master主库。

通过以上3步,就可以轻松使用MP切换多数据源的能力了。当然,除了支持主从模式,还支持多主多从、多库,混合模式。

原理探究

打开dynamic-datasource-spring-boot-starter.jar包,在spring.factories文件中,可以看到配置了DynamicDataSourceAutoConfiguration启动类。

打开DynamicDataSourceAutoConfiguration类,可以看到通过@AutoConfigureBefore注解,提前初始化了MP自己的DataSource数据源。

而DataSourceAutoConfiguration类的核心作用就是初始化DataSrouce,MP通过抢先配置的方式,使DataSource变成了自己指定的数据源。

除了初始化MP自己的数据源,DynamicDataSourceAutoConfiguration类还做了一些其他的初始化工作,比如DynamicDataSourceProperties配置,初始化DS注解的切面Advisor等。

初始化工作做完以后,接下来就是根据DS注解判断走哪个数据源了。

DynamicDataSourceAnnotationInterceptor类是一个方法拦截器,它的invoke里面有判断DS key的操作。

在determineDatasourceKey方法中,会调用提前注入的DataSourceClassResolver类的findKey方法,判断类或者方法上是否指定了DS注解。

在这个方法中,MP会将方法的判断结果缓存下来,下次执行相同的类方法就可以直接缓存,从而大大提升查找效率。

获取到dsKey以后,会将其设置在DynamicDataSourceContextHolder中的LOOKUP_KEY_HOLDER中,它是一个泛型为Deque的ThreadLocal,为什么设置成栈呢?官方给出的解释是:

接下来就是获取数据库链接的AbstractRoutingDataSource类的getConnection方法,

而determineDataSource方法就会去获取指定的数据源,

这里的逻辑是:如果没有指定DS,就走主库,如果指定了DS,就根据DS的属性值进行条件匹配,看走哪个判断分支。

获取到connection链接之后,接下来就是执行真正的数据库语句了。

以上就是一个常见的数据库操作的流程,大体思路就是先找MP的启动类,看看启动类都做了哪些工作,之后再按照找数据源,找链接的思路,看MP是如何具体实现多数据源切换的操作的。

当然,MP多数据源还有其他的功能点,但整体来说,代码逻辑并不是很复杂,大家可以通过debug对源码进行梳理。

写文不易,感谢您的点赞和关注。


http://www.ppmy.cn/news/20334.html

相关文章

代码随想录--二叉树章节总结 Part II

代码随想录–二叉树章节总结 Part II 1.Leetcode222 求完全二叉树结点的个数 给你一棵 完全二叉树 的根节点 root &#xff0c;求出该树的节点个数。 完全二叉树 的定义如下&#xff1a;在完全二叉树中&#xff0c;除了最底层节点可能没填满外&#xff0c;其余每层节点数都达…

技术大佬说我对「压测目标」的分析不够细

前言 前面总结压测类型的时候有简单描述了不同压测类型的从准备-脚本设计-压测的整体过程&#xff0c;但是对于压测对象没有更深入的进行分析总结&#xff0c;导致在压测执行结束后&#xff0c;出现压测结果不准确的情况。所以这边就压测的对象进行单独的总结分析。 在执行压测…

Lua 变量

Lua 变量 参考至菜鸟教程。 变量在使用前&#xff0c;需要在代码中进行声明&#xff0c;即创建该变量。 变量需要标识类型是因为编译程序执行代码之前需要知道如何给语句变量开辟存储区&#xff0c;用于存储变量的值。 Lua变量有三种类型&#xff1a;全局变量、局部变量、表中的…

JDBC(powernode 文档)(内含源代码)

源代码下载地址链接&#xff1a;https://download.csdn.net/download/weixin_46411355/87400304 目录 JDBC概述 1.1 前言 1.2 什么是JDBC 1.3 JDBC的原理 1.4 程序员&#xff0c;JDBC&#xff0c;JDBC驱动的关系及说明 1.4.1 JDBC API 1.4.2 JDBC 驱动 1.4.3 Java程序员…

七个 Vue 项目用得上的 JavaScript 库分享

文章目录前言一、vueuse二、vue-js-modal三、vue-wait四、good-table五、vue-notification六、tree select七、egjs-infinite grid总结前言 借助开源库加速 Vue 项目的开发进度是现代前端开发比较常见的方式&#xff0c;平常收集一些 JavaScript 库介绍&#xff0c;在遇到需要的…

C++11 并发指南五(std condition_variable 条件变量 详解)

C11 并发指南五(std::condition_variable 详解) 前面三讲《C11 并发指南二(std::thread 详解)》&#xff0c;《C11 并发指南三(std::mutex 详解)》分别介绍了 std::thread&#xff0c;std::mutex&#xff0c;std::future 等相关内容&#xff0c;相信读者对 C11 中的多线程编程有…

Qt扫盲-QObject对象和线程

QObject对象和线程一、概述二、QObjectReentrant性三、每个线程事件的循环四、从其他线程访问QObject的子类五、跨线程的信号和槽函数一、概述 QThread继承QObject。QThread它发出信号来指示线程开始或结束执行&#xff0c;还提供了一些任务槽。 Qobject可以在多个线程中使用…

【蓝桥杯】历届真题 回文日期(省赛)Java

【资源限制】 内存限制&#xff1a;256.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 【问题描述】 2020年春节期间&#xff0c;有一个特殊的日期引起了大家的注意:2020年2月2日。因为如果将这个日期按“yyyymmdd”的…