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);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值