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

前言

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#默认主库名为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<String>的ThreadLocal,为什么设置成栈呢?官方给出的解释是:

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

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

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

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

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

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

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/246489.html<

(0)
运维的头像运维
上一篇2025-04-26 16:23
下一篇 2025-04-26 16:24

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注