百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

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

wptr33 2025-03-24 21:26 22 浏览

前言

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

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

使用方法

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


  com.baomidou
  dynamic-datasource-spring-boot-starter
  ${version}

2,配置多数据源。

spring:
  datasource:
    dynamic:
      primary: master #默认主库名为master
      strict: false #不使用严格模式
      datasource:
        master:
          url: jdbc:mysql://127.0.0.1:3306/master
          username: root
          password: 66668888
          driver-class-name: com.mysql.jdbc.Driver 
        slave_1:
          url: jdbc:mysql://127.0.0.1:3307/slave_1
          username: root
          password: 66668888
          driver-class-name: com.mysql.jdbc.Driver
        slave_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对源码进行梳理。


#头条创作挑战赛#

我是@程序员拾山,欢迎关注我,期待与大家一起学习成长,也感谢您的点赞和关注。

相关推荐

什么是Java中的继承?如何实现继承?

什么是继承?...

Java 继承与多态:从基础到实战的深度解析

在面向对象编程(OOP)的三大支柱中,继承与多态是构建灵活、可复用代码的核心。无论是日常开发还是框架设计,这两个概念都扮演着至关重要的角色。本文将从基础概念出发,结合实例与图解,带你彻底搞懂Java...

Java基础教程:Java继承概述_java的继承

继承概述假如我们要定义如下类:学生类,老师类和工人类,分析如下。学生类属性:姓名,年龄行为:吃饭,睡觉老师类属性:姓名,年龄,薪水行为:吃饭,睡觉,教书班主任属性:姓名,年龄,薪水行为:吃饭,睡觉,管...

java4个技巧:从继承和覆盖,到最终的类和方法

日复一日,我们编写的大多数Java只使用了该语言全套功能的一小部分。我们实例化的每个流以及我们在实例变量前面加上的每个@Autowired注解都足以完成我们的大部分目标。然而,有些时候,我们必须求助于...

java:举例说明继承的概念_java继承的理解

在现实生活中,继承一般指的是子女继承父辈的财产。在程序中,继承描述的是事物之间的所属关系,通过继承可以使多种事物之间形成一种关系体系。例如猫和狗都属于动物,程序中便可以描述为猫和狗继承自动物,同理,...

从零开始构建一款开源的 Vibe Coding 产品 Week1Day4:业界调研之 Agent 横向对比

前情回顾前面两天我们重点调研了了一下Cursor的原理和Cursor中一个关键的工具edit_file的实现,但是其他CodingAgent也需要稍微摸一下底,看看有没有优秀之处,下...

学会这几个插件,让你的Notepad++使用起来更丝滑

搞程序开发的小伙伴相信对Notepad++都不会陌生,是一个占用空间少、打开启动快的文件编辑器,很多程序员喜欢使用Notepad++进行纯文本编辑或者脚本开发,但是Notepad++的功能绝不止于此,...

将 node_modules 目录放入 Git 仓库的优点

推荐一篇文章Whyyoushouldcheck-inyournodedependencies[1]...

再度加码AI编程,腾讯发布AI CLI并宣布CodeBuddy IDE开启公测

“再熬一年,90%的程序员可能再也用不着写for循环。”凌晨两点半,王工还在公司敲键盘。他手里那份需求文档写了足足六页,产品经理反复改了三次。放在过去,光数据库建表、接口对接、单元测试就得写两三天。现...

git 如何查看stash的内容_git查看ssh key

1.查看Stash列表首先,使用gitstashlist查看所有已保存的stash:...

6万星+ Git命令懒人必备!lazygit 终端UI神器,效率翻倍超顺手!

项目概览lazygit是一个基于终端的Git命令可视化工具,通过简易的TUI(文本用户界面)提升Git操作效率。开发者无需记忆复杂命令,即可完成分支管理、提交、合并等操作。...

《Gemini CLI 实战系列》(一)Gemini CLI 入门:AI 上命令行的第一步

谷歌的Gemini模型最近热度很高,而它的...

deepin IDE新版发布:支持玲珑构建、增强AI智能化

IT之家8月7日消息,深度操作系统官方公众号昨日(8月6日)发布博文,更新推出新版deepin集成开发环境(IDE),重点支持玲珑构建。支持玲珑构建deepinIDE在本次重磅更...

狂揽82.7k的star,这款开源可视化神器,轻松创建流程图和图表

再不用Mermaid,你的技术文档可能已经在悄悄“腐烂”——图表版本对不上、同事改完没同步、评审会上被一句“这图哪来的”问得哑口无言。这不是危言耸听。GitHub2025年开发者报告显示,63%的新仓...

《Gemini CLI 实战系列》(五)打造专属命令行工具箱

在前几篇文章中,我们介绍了GeminiCLI的基础用法、效率提升、文件处理和与外部工具结合。今天我们进入第五篇...