dynamic-datasource-spring-boot-starter实现动态数据源Mysql和Sqlserver

场景

若依前后端分离版本地搭建开发环境并运行项目的教程:

若依前后端分离版手把手教你本地搭建环境并运行项目_本地运行若依前后端分离-优快云博客

若依微服务版手把手教你本地搭建环境并运行前后端项目:

若依微服务版手把手教你本地搭建环境并运行前后端项目-优快云博客

在上面使用前后端分离的架构和微服务的架构将项目搭建起来之后,默认连接的

是一个Mysql数据库。

然后若依自带对多数据源的支持,

但是前后端分离版的配置了多数据源之后,需要在每个方法上添加注解进行区分

使用微服务版的,可以单独抽离出一个服务,使整个服务都连接到另一个数据源。

但是如果在同一个服务中,除了某个特殊的业务需要单独连接Sqlserver数据库,其他

正常请求Mysql主库的数据。

可以使用dynamic-datasource-spring-starter,基于 S

### 动态加载多数据源的解决方案 `dynamic-datasource-spring-boot-starter` 是一款强大的工具,用于支持 Spring Boot 应用中的多数据源动态切换功能。以下是针对其在动态加载多数据源过程中可能出现的问题及其解决方案。 #### 1. 配置文件设置不正确 如果配置文件未按照 `dynamic-datasource-spring-boot-starter` 的规范进行定义,则可能导致无法正常加载多数据源。通常情况下,需要在 `application.yml` 或 `application.properties` 中指定主数据源其他数据源的信息[^1]。 ```yaml spring: datasource: dynamic: primary: master # 主数据源名称 strict: false # 是否严格检查数据源存在 datasource: master: # 主数据源 url: jdbc:mysql://localhost:3306/master_db?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC username: root password: root driver-class-name: com.mysql.cj.jdbc.Driver slave1: # 副数据源1 url: jdbc:mysql://localhost:3306/slave1_db?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC username: root password: root driver-class-name: com.mysql.cj.jdbc.Driver slave2: # 副数据源2 url: jdbc:mysql://localhost:3306/slave2_db?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC username: root password: root driver-class-name: com.mysql.cj.jdbc.Driver ``` #### 2. 数据源动态注册失败 当需要通过程序运行时动态添加新的数据源时,可能会因为缺少必要的初始化逻辑而导致失败。可以通过以下方式实现动态注册: ```java import org.springframework.context.ApplicationContext; import javax.sql.DataSource; public class DynamicDataSourceRegister { private final ApplicationContext applicationContext; public DynamicDataSourceRegister(ApplicationContext applicationContext) { this.applicationContext = applicationContext; } public void addDataSource(String name, DataSource dataSource) { DynamicRoutingDataSource dynamicDataSource = applicationContext.getBean(DynamicRoutingDataSource.class); dynamicDataSource.addDataSource(name, dataSource); // 添加新数据源到路由管理器中 } } ``` 此代码片段展示了如何利用 `DynamicRoutingDataSource` 来动态注册一个新的数据源[^2]。 #### 3. MyBatis 支持不足 如果项目中集成了 MyBatis 并希望它能适配多数据源环境,需确保引入了兼容版本的依赖项。例如,在 Maven 项目的 `pom.xml` 文件中应包含如下内容: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>dynamic-datasource-spring-boot-starter</artifactId> <version>3.5.0</version> </dependency> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.2.2</version> </dependency> ``` 此外,还需确认 MyBatis 映射文件路径已正确定义,并且 SQL Session 已绑定至当前线程使用的具体数据源实例[^2]。 #### 4. 性能优化建议 为了提高性能并减少资源消耗,可以考虑启用连接池技术来管理各个数据源之间的链接分配情况。推荐使用 HikariCP 这样的高性能 JDBC 连接池库作为默认选项之一。 --- ### 示例代码展示 下面提供了一个简单的例子说明如何结合 MyBatis 使用该插件完成基本查询操作: ```java @Service @DS("slave1") // 切换到名为 'slave1' 的数据源执行后续操作 public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public List<User> getAllUsers() { return userMapper.selectAll(); } } ``` 在此案例里,`@DS` 注解被用来显式指明目标数据源为 `slave1`[^1]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

霸道流氓气质

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

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

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

打赏作者

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

抵扣说明:

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

余额充值