springBoot(六) 调用多数据源 dynamic-datasource

匿名 (未验证) 提交于 2019-12-03 00:09:02

1 dynamic-datasource简介

  • 本框架只做 切换数据源 这件核心的事情,并不限制您的具体操作。
  • 强烈建议在 主从模式
  • 下遵循普遍的规则,以便他人能更轻易理解您的代码。
  • 主数据库 建议 只执行 INSERT UPDATE DELETE 操作。
  • 从数据库 建议 只执行 SELECT 操作。

2 使用方法

2.1 引入dynamic-datasource-spring-boot-starter

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

2.2 spring boot 配置(yml)

一主多从方案

spring:   datasource:     dynamic:       primary: master #设置默认的数据源或者数据源组,默认值即为master,如果你主从默认下主库的名称就是master可不定义此项。       datasource:         master:           username: root           password: 123456           driver-class-name: com.mysql.jdbc.Driver           url: jdbc:mysql://47.xxx.xx.xxx:3306/dynamic?characterEncoding=utf8&useSSL=false         slave_1:           username: root           password: 123456           driver-class-name: com.mysql.jdbc.Driver           url: jdbc:mysql://47.xxx.xx.xxx:3307/dynamic?characterEncoding=utf8&useSSL=false         slave_2:           username: root           password: 123456           driver-class-name: com.mysql.jdbc.Driver           url: jdbc:mysql://47.xxx.xx.xxx:3308/dynamic?characterEncoding=utf8&useSSL=false        #......省略        #以上会配置一个默认库master,一个组slave下有两个子库slave_1,slave_2 

多主多从方案

spring:   datasource:     dynamic:       datasource:         master_1:         master_2:         slave_1:         slave_2:         slave_3: 

多数据库方案

spring:   datasource:     dynamic:       primary: mysql #记得设置一个默认数据源       datasource:         mysql:         oracle:         sqlserver:          h2: 

3 使用注解

3.1 注解介绍

@DS 可以注解在方法上和类上,同时存在方法注解优先于类上注解,强烈建议注解在service实现或mapper接口方法上。

注意从2.0.0 不再支持@DS空注解 ,您 必须 指明你所需要的数据库 组名 或者 具体某个数据库名称 。

注解 结果
没有@DS 默认数据源
@DS(“dsName”) dsName可以为组名也可以为具体某个库的名称

注解可以使用在sevice 和 mapper 层, 可以用在方法个类上

4 继承druid

springBoot 2.x默认是使用HikariCP的, 所以觉得HikariCP的可以不需要换Druid,因为国内用多还是写一下

**注意:**主从可以使用不同的数据库连接池,如master使用Druid监控,从库使用HikariCP。 如果不配置连接池type类型,默认是Druid优先于HikariCP。

4.1 排除原生的Druid配置

@SpringBootApplication(exclude = DruidDataSourceAutoConfigure.class) public class Application {    public static void main(String[] args) {     SpringApplication.run(Application.class, args);   }  } 

4.2 导入druid包之后配置yml

spring:   datasource:     druid:       stat-view-servlet:         loginUsername: root         loginPassword: root     dynamic:       datasource:         master:           username: root           password: root           driver-class-name: com.mysql.cj.jdbc.Driver           url: jdbc:mysql://120.xxx.xxx.xxx:3316/aaaa?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai           druid: #以下均为默认值             initial-size: 3             max-active: 8             min-idle: 2             max-wait: -1             min-evictable-idle-time-millis: 30000             max-evictable-idle-time-millis: 30000             time-between-eviction-runs-millis: 0             validation-query: select 1             validation-query-timeout: -1             test-on-borrow: false             test-on-return: false             test-while-idle: true             pool-prepared-statements: true             max-open-prepared-statements: 100             filters: stat,wall             share-prepared-statements: true         slave_1:           username: root           password: root           driver-class-name: com.mysql.cj.jdbc.Driver           url: jdbc:mysql://120.xx.xx.xxx:3317/aaaa?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai           druid: #以下均为默认值             initial-size: 3             max-active: 8             min-idle: 2             max-wait: -1             min-evictable-idle-time-millis: 30000             max-evictable-idle-time-millis: 30000             time-between-eviction-runs-millis: 0             validation-query: select 1             validation-query-timeout: -1             test-on-borrow: false             test-on-return: false             test-while-idle: true             pool-prepared-statements: true             max-open-prepared-statements: 100             filters: stat,wall             share-prepared-statements: true  

小结

  • 在项目不打的时候可以使用这个,但是一旦数据库多了,那么用dynamic-datasource 就会导致后期维护十分麻烦所以业务十分大建议使用 sharding-jdbc
  • 一定要记得需要将原生的Druid的配置 隔离掉
  • 数据库主从分离要做好
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!