当前位置: 首页 > news >正文

Spring Boot 和 MyBatis 环境下实现动态数据源切换

使用 dynamic-datasource-spring-boot-starter 是在 Spring Boot 和 MyBatis 环境下实现动态数据源切换最简单和高效的方式。

这个 Starter 极大地简化了配置和切换逻辑,它自身集成了 AbstractRoutingDataSource 的所有逻辑。


使用 dynamic-datasource-spring-boot-starter

1. 引入依赖

在您的 Maven 或 Gradle 项目中引入 Starter 依赖。

Maven:

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

2. 配置文件(application.ymlapplication.properties

您只需在配置文件中定义所有的数据源。Starter 会自动将它们注册和管理起来。

它约定:

  • spring.datasource.dynamic.primary:指定默认使用的数据源名称(Key)。
  • spring.datasource.dynamic.datasource:在下面配置您的具体数据源。

application.yml 示例:

spring:# 动态数据源配置datasource:dynamic:# 默认数据源,未指定时将使用这个primary: masterdatasource:# 主库配置 (Key: master)master:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://localhost:3306/db_master?serverTimezone=Asia/Shanghaiusername: rootpassword: 123# 从库配置 (Key: slave)slave:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://localhost:3306/db_slave?serverTimezone=Asia/Shanghaiusername: rootpassword: 123

3. 实现数据源动态切换

Starter 提供了 @DS 注解来实现数据源的动态切换。这个注解可以直接用于 Service 层的方法、Mapper 接口的方法,甚至整个 Mapper 类上。

示例 1: 在 Service 层方法上切换

这是最常见的用法,因为 Service 层更贴近业务逻辑。

import com.baomidou.dynamic.datasource.annotation.DS;
import org.springframework.stereotype.Service;@Service
public class UserService {// 默认使用 primary 配置的数据源,即 masterpublic User getMasterUser(Long id) {// ... 逻辑}// 明确指定使用 slave 数据源,常用于查询@DS("slave")public List<User> getSlaveUsers() {// ... 逻辑,此方法执行期间会使用 slave 库return userMapper.selectAll();}// 明确指定使用 master 数据源,常用于事务性的更新操作@DS("master")public void updateMasterUser(User user) {// ... 逻辑,此方法执行期间会使用 master 库userMapper.update(user);}
}
示例 2: 在 Mapper 接口或方法上切换

您也可以直接在 Mapper 接口上指定数据源,但通常不推荐将数据源的决策放在持久层。

import com.baomidou.dynamic.datasource.annotation.DS;
import org.apache.ibatis.annotations.Mapper;// 整个 Mapper 接口都使用 slave 数据源
@DS("slave")
@Mapper
public interface SlaveUserMapper {List<User> selectAll();// 如果某个方法需要覆盖类上的配置,可以再次使用 @DS@DS("master")User selectById(Long id); 
}

额外高级功能

dynamic-datasource-spring-boot-starter 除了基础的动态切换外,还提供了一些非常实用的高级功能:

1. 读写分离(Load Balance)

该 Starter 原生支持基于的负载均衡。

配置示例:

spring:datasource:dynamic:primary: master-group # 默认使用 master-groupdatasource:# 定义一个名为 master-group 的组,它包含一个主库和两个从库master-group:# 主库master:url: ...# 从库 1slave1:url: ...# 从库 2slave2:url: ...

使用方式:

  • 写入操作(默认): 当您使用 @DS("master-group") 进行 写操作(UPDATE/INSERT/DELETE) 时,会自动连接到组内的 master 库。
  • 读取操作(负载均衡): 当您使用 @DS("master-group") 进行 读操作(SELECT) 时,会在 slave1slave2 之间进行负载均衡(默认是轮询)。

2. 运行时添加/删除数据源

该 Starter 提供了 DynamicDataSourceService 接口,允许您在项目运行期间,通过代码动态地添加或删除数据源,这对于多租户等场景非常有用。

@Autowired
private DynamicDataSourceCreator dynamicDataSourceCreator;@Autowired
private DynamicDataSource dynamicDataSource;public void addTenantDataSource(String tenantId, DataSourceProperty dp) {// 1. 创建新的数据源(例如使用 Druid 或 Hikari 配置)DataSource newDs = dynamicDataSourceCreator.createDataSource(dp);// 2. 将数据源添加到动态数据源管理器中dynamicDataSource.addDataSource(tenantId, newDs);
}

总之,使用 @DS 注解和简洁的配置,dynamic-datasource-spring-boot-starter 是解决 MyBatis 动态数据源问题的最佳实践

http://www.dtcms.com/a/456874.html

相关文章:

  • 2025 年度国产大模型「开源 vs. 闭源」深度评测与实战指南
  • 网页设计与网站建设电话香洲网站建设
  • 移动论坛网站模板免费下载revolution slider wordpress
  • TPM(Total Productive Maintenance)现场管理
  • 从 0 到 1 搭建 Python 语言 Web UI自动化测试学习系列 11 自动化测试--框架设计--基础知识 7--各种弹窗处理
  • ubuntu terminal 设置代理
  • 《传感器与检测技术》第 2 章 电阻式传感器原理与应用
  • Linux中input子系统
  • 探索Linux:开源世界的钥匙
  • GitHub 热榜项目 - 日榜(2025-10-08)
  • 手写Function.prototype.bind:从原理到完整实现
  • 百度做网站的公司施工企业的施工现场消防安全责任人应是
  • 做电商网站报价网站开发工程师需要会写什么
  • (3)容器布局进阶:Spacer、Divider、Frame 与 Alignment
  • 墨西哥证券交易所(BMV)等多个交易所股票数据API对接文档
  • 【数据分析与可视化】2025年一季度金融业主要行业资产、负债、权益结构与增速对比
  • app网站建设阿里巴巴卓拙科技做网站吗
  • 乌苏市城乡建设局网站北京朝阳区邮政编码
  • 个人用云计算学习笔记 --18(NFS 服务器、iSCSI 服务器)
  • 智能制造——解读MES在各行业中的需求与解决方案【附全文阅读】
  • 老题新解|棋盘覆盖
  • 网站可不可以做自己的专利东莞沙田网站建设
  • Redis Hash 全解析:从入门到精通,解锁高性能对象存储的钥匙
  • 14.排序
  • Python自动化实战第一篇: 自动化备份100+台服务器Web 配置
  • 第五十二章 ESP32S3 UDP 实验
  • [鹤城杯 2021]Misc2
  • 山东省旅游网站建设网络设计是干什么的工作
  • 基于 ZYNQ ARM+FPGA+AI YOLOV4 的电网悬垂绝缘子缺陷检测系统的研究
  • 开源 C++ QT QML 开发(十二)通讯--TCP客户端