MybatisPlus 配置多数据源

前言

项目之前用的是 Postgresql 数据库,但因为日志相关数据量比较大入库效率很低,而且关于日志相关的数据查询效率也在变慢。所以决定启用 clickhouse,因为 clickhouse 支持大量数据的批量入库,并且查询效率也极高(战斗民族开发的,可想而知,简单粗暴,极致追求效率)。引入 clickhouse 只针对日志相关的数据库,其他业务相关的数据库表依然沿用 Postgresql,所以项目要支持多数据源。

项目原本就是采用的 MybatisPlus,所以在支持多数据源的时候是很简单的。当然,如果原来用的是 Mybatis,要支持多数据源的话,要复杂一些,不过实现起来也是比较容易,这里先介绍 MybatisPlus 支持多数据源配置。

clickhouse 感性趣的,可以看下官方文档,尽量少看一些博客资料,因为版本更新太快了,基本上一个月一版,链接地址:clickhouse 官方文档

配置信息

Jar 包引入
<!--mybatis-plus相关-->
<dependency>
  <groupId>com.baomidou</groupId>
  <artifactId>mybatis-plus-boot-starter</artifactId>
  <version>3.5.2</version>
</dependency>
<dependency>
  <groupId>com.baomidou</groupId>
  <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
  <version>3.5.2</version>
</dependency>
<!--postgresql驱动-->
<dependency>
  <groupId>org.postgresql</groupId>
  <artifactId>postgresql</artifactId>
  <version>42.5.0</version>
</dependency>
<!--clickhouse驱动-->
<dependency>
  <groupId>ru.yandex.clickhouse</groupId>
  <artifactId>clickhouse-jdbc</artifactId>
  <version>0.3.2</version>
</dependency>
application.yml 配置
spring:
  datasource:
    dynamic:
      primary: master # 默认数据源
      strict: false # 是否严格匹配数据源,false 未匹配到使用默认数据源 true 未匹配到会抛出异常
      datasource:
        master:
          driver-class-name: org.postgresql.Driver
          url: jdbc:postgresql://10.70.70.4:5432/postgres
          username: postgres
          password: postgres
        slave:
          driver-class-name: ru.yandex.clickhouse.ClickHouseDriver
          url: jdbc:clickhouse://10.70.70.4:8123/default

测试案例

我们使用的时候,将注解 @DS("slave") 加在需要操作 clickhouse 数据库的类上面或者方法上。特别注意的是,如果两个地方都添加的话,会优先使用类上面的注解配置。

如果我们想正常操作 Postgresql,什么操作都不用,因为我们配置的 master 默认数据源是 Postgresql

@DS("slave")
@Service
public class LogAuditService extends ServiceImpl<LogAuditMapper, LogAudit> {

    public List<LogAudit> getLogAuditList() {
        return this.list();
    }
    
    @DS("slave")
    public LogAudit getLogAuditById(Long id) {
        return this.getById(id);
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SpringBoot结合MyBatisPlus配置多数据源的示例代码主要包括以下几个步骤[^1][^2]: 1. **配置文件信息**: 在`application.properties`或`application.yml`中添加多数据源配置,例如: ```properties # 主数据源配置 spring.datasource.master.url=jdbc:mysql://localhost:3306/master_db spring.datasource.master.username=root spring.datasource.master.password=master_password # 备份数据源配置 spring.datasource_slave.url=jdbc:mysql://localhost:3306/backup_db spring.datasource_slave.username=root spring.datasource_slave.password=backup_password # 数据源切换相关配置 spring.aop.auto=true data-source-switch.datasource-names=master,slave ``` 2. **多数据源配置类**: 创建一个`DataSourceSwitch`配置类,通常会继承`AbstractRoutingDataSource`或自定义实现: ```java import org.springframework.jdbc.datasource.lookup.DataSourceLookupFailureException; import org.springframework.jdbc.datasource.lookup.DataSourceUtils; public class DataSourceSwitch extends AbstractRoutingDataSource { private String dataSourceName; @Override protected Object determineCurrentLookupKey() { return dataSourceName; } // 在需要切换数据源的地方调用此方法 public void switchDataSource(String dataSourceName) { this.dataSourceName = dataSourceName; try { setTargetDataSource(DataSourceUtils.getConnection(dataSourceName)); } catch (DataSourceLookupFailureException e) { throw new RuntimeException("切换数据源失败", e); } } } ``` 3. **动态数据源切换**: 使用Spring AOP在需要访问数据库的地方自动切换数据源,比如在Repository接口上添加切面: ```java @Aspect @Configuration public class DataSourcesAspect { @Autowired private DataSourceSwitch dataSourceSwitch; @Before("execution(* com.example.repository.*.*(..))") public void switchDataSource(JoinPoint joinPoint) { MethodSignature signature = (MethodSignature) joinPoint.getSignature(); String methodName = signature.getMethod().getName(); dataSourceSwitch.switchDataSource(methodName.equals("master") ? "master" : "slave"); } } ``` 4. **MyBatisPlus配合**: 在MyBatisPlus的全局配置类中,注入数据源,这样MyBatisPlus就会自动使用当前的数据源: ```java @Configuration public class GlobalConfig { @Autowired private DataSourceSwitch dataSourceSwitch; @Bean public GlobalConfig globalConfig() { GlobalConfig config = new GlobalConfig(); config.setDataSource(dataSourceSwitch.getTargetDataSource()); return config; } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值