当前位置:   article > 正文

springboot多数据源dynamic-datasource方式

dynamic-datasource

背景

项目中需要连接多个数据源,可能是一主多从,或者不同的多数据源,或者多个不同类型的数据源如项目中有mysql库也有oracle

具体配置

1.pom配置

  1. <dependency>
  2. <groupId>org.mybatis.spring.boot</groupId>
  3. <artifactId>mybatis-spring-boot-starter</artifactId>
  4. <version>2.0.1</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>com.baomidou</groupId>
  8. <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
  9. <version>2.5.5</version>
  10. </dependency>
  11. <dependency>
  12. <groupId>mysql</groupId>
  13. <artifactId>mysql-connector-java</artifactId>
  14. </dependency>

2.mybatis扫描地址配置

mybatis的扫描地址

  1. mybatis:
  2. type-aliases-package: com.cv.model
  3. mapper-locations: classpath:mybatis/mappers/**/*.xml
  4. config类上或者启动类上
  5. @MapperScan(basePackages = {"com.cv.dao"})

3.数据源配置

  1. spring:
  2. datasource:
  3. dynamic:
  4. primary: master
  5. strict: false
  6. hikari:
  7. min-idle: 10
  8. idle-timeout: 60000
  9. max-pool-size: 20
  10. connection-timeout: 60000
  11. connection-test-query: SELECT 1
  12. max-lifetime: 0
  13. datasource:
  14. master:
  15. type: com.zaxxer.hikari.HikariDataSource
  16. url: jdbc:mysql://ip:port/instance?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull
  17. username:
  18. password:
  19. driverClassName: com.mysql.cj.jdbc.Driver
  20. slave:
  21. type: com.zaxxer.hikari.HikariDataSource
  22. url: jdbc:mysql://ip:port/instance?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull
  23. username:
  24. password:
  25. driverClassName: com.mysql.cj.jdbc.Driver
  26. orc:
  27. hikari:
  28. min-idle: 10
  29. idle-timeout: 180000
  30. max-pool-size: 20
  31. connection-timeout: 30000
  32. connection-test-query: SELECT 1 from dual
  33. max-lifetime: 1800000
  34. url: jdbc:oracle:thin:@ip:port
  35. username:
  36. password:
  37. driverClassName: oracle.jdbc.driver.OracleDriver

4.切换数据源

  1. import com.baomidou.dynamic.datasource.annotation.DS;
  2. @DS("stat")
  3. @DS可以注解在方法上、类上、接口、枚举,同时存在方法注解优先于类上注解。

5.需要注意的问题

  1. 一:涉及需要切换数据源时
  2. 1.不能使用事务,否则数据源不会切换,使用的还是是第一次加载的数据源 。
  3.   删除 操作多数据源的方法或者类、接口 上的 注解 @Transactional() 即可。
  4. 2.第一次加载的数据源之后,第二次(第三次...)操作其它数据源,如果数据源不存在,使用的还是第一
  5. 次加载的数据源
  6. 3.数据源名称最好不要包含下滑线,下滑线的数据源切换不了
  7. 二:其他
  8. 1.接口中AB两个方法,A无@Transactional标签,B有,上层通过A间接调用B,此时事务不生效。
  9. 2.接口中异常(运行时异常)被捕获而没有被抛出。
  10. 默认配置下,spring 只有在抛出的异常为运行时 unchecked 异常时才回滚该事务,
  11. 也就是抛出的异常为RuntimeException 的子类(Errors也会导致事务回滚),
  12. 而抛出 checked 异常则不会导致事务回滚 。可通过 @Transactional rollbackFor进行配置。
  13. 3.多线程下事务管理因为线程不属于 spring 托管,故线程不能够默认使用 spring 的事务,
  14. 也不能获取spring 注入的 bean
  15. 在被 spring 声明式事务管理的方法内开启多线程,多线程内的方法不被事务控制。
  16. 一个使用了@Transactional 的方法,如果方法内包含多线程的使用,方法内部出现异常,
  17. 不会回滚线程中调用方法的事务。

附上最近搭建的一个快速功能开发框架,附带各种快速开发插件,仅为提高工作效率。

链接:springboot + mybatis-plus + oracle + 多数据源 + redis + hutool

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/677961
推荐阅读
相关标签
  

闽ICP备14008679号