温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Springboot 中如何使用dynamic-datasource实现解决多数据源问题

发布时间:2020-11-19 15:31:56 来源:亿速云 阅读:1671 作者:Leah 栏目:开发技术

本篇文章给大家分享的是有关Springboot 中如何使用dynamic-datasource实现解决多数据源问题,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

依赖

<dependency>
  <groupId>com.baomidou</groupId>
  <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
  <version>2.5.0</version>
</dependency>
<dependency>
  <groupId>p6spy</groupId>
  <artifactId>p6spy</artifactId>
  <version>3.9.1</version>
</dependency>
<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>druid-spring-boot-starter</artifactId>
  <version>1.1.21</version>
</dependency>
<dependency>
  <groupId>com.baomidou</groupId>
  <artifactId>mybatis-plus-boot-starter</artifactId>
  <version>3.3.1.tmp</version>
</dependency>

p6spy配置文件spy.properties,有性能影响,生产环境建议关闭

#3.2.1以上使用
modulelist=com.baomidou.mybatisplus.extension.p6spy.MybatisPlusLogFactory
#3.2.1以下使用或者不配置
#modulelist=com.p6spy.engine.logging.P6LogFactory,com.p6spy.engine.outage.P6OutageFactory
# 自定义日志打印
logMessageFormat=com.baomidou.mybatisplus.extension.p6spy.P6SpyLogger
#日志输出到控制台
appender=com.baomidou.mybatisplus.extension.p6spy.StdoutLogger
# 使用日志系统记录 sql
#appender=com.p6spy.engine.spy.appender.Slf4JLogger
# 设置 p6spy driver 代理
deregisterdrivers=true

# 取消JDBC URL前缀
useprefix=true
# 配置记录 Log 例外,可去掉的结果集有error,info,batch,debug,statement,commit,rollback,result,resultset.
excludecategories=info,debug,result,commit,resultset
# 日期格式
dateformat=yyyy-MM-dd HH:mm:ss
# 实际驱动可多个
#driverlist=org.h3.Driver
# 是否开启慢SQL记录
outagedetection=true
# 慢SQL记录标准 2 秒
outagedetectioninterval=5

配置文件application.yml

server:
 port: 8080

spring:
 datasource:
  dynamic:
   p6spy: true # 默认false,建议线上关闭。
   primary: master #设置默认的数据源或者数据源组,默认值即为master
   datasource:
    master:
     url: jdbc:mysql://localhost:3306/bdata&#63;serverTimezone=GMT%2B8&characterEncoding=utf8&autoReconnect=true&rewriteBatchedStatements=true&allowMultiQueries=true
     username: root
     password: root
     driver-class-name: com.mysql.cj.jdbc.Driver
    slave:
     url: jdbc:mysql://localhost:3306/lmkstudy&#63;serverTimezone=GMT%2B8&characterEncoding=utf8&autoReconnect=true&rewriteBatchedStatements=true&allowMultiQueries=true
     username: root
     password: root
     driver-class-name: com.mysql.cj.jdbc.Driver
     druid:
      password: root
      username: root
      # 初始化连接大小
      initial-size: 5
      #最大连接池数量
      max-active: 20
      # 最小连接池数量
      min-idle: 3
      # 配置获取连接等待超时的时间 单位毫秒
      max-wait: 60000
      # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
      time-between-eviction-runs-millis: 60000
      # 配置一个连接在池中最小生存的时间,单位是毫秒
      min-evictable-idle-time-millis: 300000
      # 测试连接
      validation-query: select
      # 申请连接的时候检测,建议配置为true,不影响性能,并且保证安全性
      test-while-idle: true
      # 获取连接时执行检测,建议关闭,影响性能
      test-on-borrow: false
      # 归还连接时执行检测,建议关闭,影响性能
      test-on-return: false
      # 打开PSCache,并且指定每个连接上PSCache的大小
      pool-prepared-statements: true
      #   配置监控统计拦截器 防火墙 日志配置
      #   stat监控数据库性能
      #   wall 用于防火墙
      #   日志 slf4j logback
      #   log4j
      #   log4j2
      # 配置多个英文逗号分隔
      filters: stat,wall,slf4j

      max-pool-prepared-statement-per-connection-size: 20
      # 合并多个DruidDataSource的监控数据
      use-global-data-source-stat: true
      # 通过connectProperties属性来打开mergeSql功能;慢SQL记录 SQL优化
      connect-properties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500
      # ===========监控配置===========
      # WebStatFilter配置,说明请参考Druid Wiki,配置_配置WebStatFilter
      web-stat-filter:
       #是否启用StatFilter默认值false
       enabled: true
       # 拦截所有的
       url-pattern: /*
       # 排除一些不必要的url,比如*:js,/jslib/*等等:
       exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico, /druid/*"
       # 关闭和开启session 统计功能 默认关闭
       #    session-stat-enable: true
       # sessionStatMaxCount是1000个
       #    session-stat-max-count: 1000
       # 配置principalSessionName,使得druid能够知道当前的session的用户是谁
       #    principal-session-name:
       # StatViewServlet配置,说明请参考Druid Wiki,配置_StatViewServlet配置
      stat-view-servlet:
       # 是否启用StatViewServlet默认值true
       enabled: true
       url-pattern: /druid/*
       # 界面上有一个重置功能 执行这个操作之后,会导致所有计数器清零,重新计数 建议false
       reset-enable: false
       # 登录的后台的用户名,密码
       login-username: admin
       login-password: admin
mybatis-plus:
 type-aliases-package: com.site.datasource.entity
 mapper-locations: classpath*:mapper/*.xml

service层添加注解@DS(“slave”),选定数据源

@DS("slave")
@Service("userService")
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {

}

启动类上添加@SpringBootApplication(exclude = DruidDataSourceAutoConfigure.class)

@SpringBootApplication(exclude = DruidDataSourceAutoConfigure.class)
public class ThreadApplication {

  public static void main(String[] args) {
    SpringApplication.run(ThreadApplication.class, args);
  }

}

遇到的坑:记得要去掉DruidConfig这个文件,不然会报错

以上就是Springboot 中如何使用dynamic-datasource实现解决多数据源问题,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI