Spring进阶:3步引入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的ThreadLocal,为什么设置成栈呢?官方给出的解释是:

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

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

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

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

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

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

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

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MyBatis-Plus 中配置多数据源可以通过以下骤完成: 1. 添加相关依赖:首先,在项目的 `pom.xml` 文件中添加 MyBatis-Plus 和数据库驱动的依赖。例如,如果你使用的是 MySQL 数据库,可以添加如下依赖: ```xml <dependencies> <!-- MyBatis-Plus --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>最新版本</version> </dependency> <!-- MySQL 驱动 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>最新版本</version> </dependency> </dependencies> ``` 2. 配置数据源:在项目的配置文件(例如 `application.yml` 或 `application.properties`)中,配置多个数据源的连接信息。每个数据源需要指定其对应的数据库驱动、URL、用户名和密码。例如: ```yaml spring: datasource: # 默认数据源配置 url: jdbc:mysql://localhost:3306/db1 username: root password: password # 第二个数据源配置 datasource2: url: jdbc:mysql://localhost:3306/db2 username: root password: password ``` 3. 配置多数据源:在配置类中,使用 `@Configuration` 注解标记该类为配置类,并使用 `@EnableTransactionManagement` 注解开启事务管理。然后,通过 `@Bean` 注解创建多个数据源,并将它们注入到 `DataSource` 类中。例如: ```java @Configuration @EnableTransactionManagement public class DataSourceConfig { @Bean @ConfigurationProperties("spring.datasource") public DataSource dataSource() { return new DruidDataSource(); } @Bean @ConfigurationProperties("spring.datasource.datasource2") public DataSource dataSource2() { return new DruidDataSource(); } } ``` 4. 配置 MyBatis-Plus:在配置类中,使用 `@MapperScan` 注解指定要扫描的 Mapper 接口的包路径,并在 `SqlSessionFactory` 上配置多个数据源。例如: ```java @Configuration @MapperScan(basePackages = "com.example.mapper") public class MybatisPlusConfig { @Autowired private DataSource dataSource; @Autowired private DataSource dataSource2; @Bean public SqlSessionFactory sqlSessionFactory() throws Exception { MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean(); sqlSessionFactory.setDataSource(dataSource); // 配置多数据源 MybatisConfiguration configuration = new MybatisConfiguration(); MapperRegistry mapperRegistry = new MapperRegistry(configuration); mapperRegistry.setKnownMappers(Collections.singletonList(BaseMapper.class)); sqlSessionFactory.setMapperRegistry(mapperRegistry); // 添加第二个数据源 SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean(); factoryBean.setDataSource(dataSource2); factoryBean.setConfiguration(configuration); return sqlSessionFactory.getObject(); } } ``` 以上就是在 MyBatis-Plus 中配置多数据源骤。配置完成后,你可以在需要使用特定数据源的地方使用 `@Qualifier` 注解指定要使用的数据源。例如,在 Service 类中使用多数据源: ```java @Service public class UserService { @Autowired @Qualifier("dataSource2") private DataSource dataSource; // 其他方法... } ``` 请注意,以上示例中使用了 Druid 数据库连接池,你也可以根据自己的需求选择其他连接池。另外,示例中的配置是基于 Spring Boot 的,如果你使用的是其他框架或纯 Spring 环境,请相应调整配置方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

程序员拾山

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

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

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

打赏作者

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

抵扣说明:

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

余额充值