springboot多数据源dynamic-datasource方式

背景

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

具体配置

1.pom配置

<dependency>
 <groupId>org.mybatis.spring.boot</groupId>
 <artifactId>mybatis-spring-boot-starter</artifactId>
 <version>2.0.1</version>
</dependency>
<dependency>
 <groupId>com.baomidou</groupId>
 <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
 <version>2.5.5</version>
</dependency>
<dependency>
 <groupId>mysql</groupId>
 <artifactId>mysql-connector-java</artifactId>
</dependency>

2.mybatis扫描地址配置

mybatis的扫描地址

mybatis:
  type-aliases-package: com.cv.model
  mapper-locations: classpath:mybatis/mappers/**/*.xml

config类上或者启动类上
@MapperScan(basePackages = {"com.cv.dao"})

3.数据源配置

spring:
  datasource:
    dynamic:
      primary: master
      strict: false
      hikari:
        min-idle: 10
        idle-timeout: 60000
        max-pool-size: 20
        connection-timeout: 60000
        connection-test-query: SELECT 1
        max-lifetime: 0
      datasource:
        master:
          type: com.zaxxer.hikari.HikariDataSource
          url: jdbc:mysql://ip:port/instance?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull
          username: 
          password: 
          driverClassName: com.mysql.cj.jdbc.Driver
        slave:
          type: com.zaxxer.hikari.HikariDataSource
          url: jdbc:mysql://ip:port/instance?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull
          username: 
          password: 
          driverClassName: com.mysql.cj.jdbc.Driver
        orc:
          hikari:
            min-idle: 10
            idle-timeout: 180000
            max-pool-size: 20
            connection-timeout: 30000
            connection-test-query: SELECT 1 from dual
            max-lifetime: 1800000
          url: jdbc:oracle:thin:@ip:port
          username: 
          password: 
          driverClassName: oracle.jdbc.driver.OracleDriver

4.切换数据源

import com.baomidou.dynamic.datasource.annotation.DS;

@DS("stat")

@DS可以注解在方法上、类上、接口、枚举,同时存在方法注解优先于类上注解。

5.需要注意的问题

一:涉及需要切换数据源时
      1.不能使用事务,否则数据源不会切换,使用的还是是第一次加载的数据源 。
       删除 操作多数据源的方法或者类、接口 上的 注解 @Transactional() 即可。
      2.第一次加载的数据源之后,第二次(第三次...)操作其它数据源,如果数据源不存在,使用的还是第一            
        次加载的数据源
      3.数据源名称最好不要包含下滑线,下滑线的数据源切换不了

二:其他
    1.接口中A、B两个方法,A无@Transactional标签,B有,上层通过A间接调用B,此时事务不生效。
 
    2.接口中异常(运行时异常)被捕获而没有被抛出。
      默认配置下,spring 只有在抛出的异常为运行时 unchecked 异常时才回滚该事务,
      也就是抛出的异常为RuntimeException 的子类(Errors也会导致事务回滚),
      而抛出 checked 异常则不会导致事务回滚 。可通过 @Transactional rollbackFor进行配置。
 
    3.多线程下事务管理因为线程不属于 spring 托管,故线程不能够默认使用 spring 的事务,
      也不能获取spring 注入的 bean 。
      在被 spring 声明式事务管理的方法内开启多线程,多线程内的方法不被事务控制。
      一个使用了@Transactional 的方法,如果方法内包含多线程的使用,方法内部出现异常,
      不会回滚线程中调用方法的事务。
 

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

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

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot中集成dynamic-datasource可以帮助我们实现动态数据源切换的功能。面是一些基本步骤: 1. 添加依赖:在pom.xml文件中添加dynamic-datasource的依赖。 ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>dynamic-datasource-spring-boot-starter</artifactId> <version>latest-version</version> </dependency> ``` 2. 配置数据源:在application.properties或application.yml文件中配置数据源信息。 ```properties # 数据源1 spring.datasource.dynamic.datasource.master.url=jdbc:mysql://localhost:3306/db1 spring.datasource.dynamic.datasource.master.username=root spring.datasource.dynamic.datasource.master.password=123456 spring.datasource.dynamic.datasource.master.driver-class-name=com.mysql.jdbc.Driver # 数据源2 spring.datasource.dynamic.datasource.slave.url=jdbc:mysql://localhost:3306/db2 spring.datasource.dynamic.datasource.slave.username=root spring.datasource.dynamic.datasource.slave.password=123456 spring.datasource.dynamic.datasource.slave.driver-class-name=com.mysql.jdbc.Driver ``` 3. 配置动态数据源:创建一个配置类,用于配置动态数据源。 ```java @Configuration public class DynamicDataSourceConfig { @Primary @Bean("dynamicDataSource") @ConfigurationProperties(prefix = "spring.datasource.dynamic") public DataSource dynamicDataSource() { return new DruidDataSource(); } @Bean public DataSourceTransactionManager transactionManager(@Qualifier("dynamicDataSource") DataSource dataSource) { return new DataSourceTransactionManager(dataSource); } @Bean public SqlSessionFactory sqlSessionFactory(@Qualifier("dynamicDataSource") DataSource dataSource) throws Exception { MybatisSqlSessionFactoryBean sessionFactory = new MybatisSqlSessionFactoryBean(); sessionFactory.setDataSource(dataSource); return sessionFactory.getObject(); } } ``` 4. 使用动态数据源:在需要使用数据源的地方,通过注解`@DS`指定数据源。 ```java @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override @DS("master") // 使用master数据源 public List<User> getMasterUsers() { return userMapper.getUsers();

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值