Springboot 集成 dynamic-datasource-spring-boot-starter,实现项目中原有的数据源作为主数据源

Springboot 集成 dynamic-datasource-spring-boot-starter,实现项目中原有的数据源作为主数据源

保证原有项目中在执行数据库操作时,默认使用原有数据源,新数据源做特定操作

引入多数据源切换依赖:

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

使用的数据库连接池依赖:

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
    <version>1.2.15</version>
</dependency>

<!-- 使用这个也没有问题,都是druid -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.1.12</version>
</dependency>

以下相关代码编写基于的配置文件:

mysql: &db-mysql
  username: 'xxxx'
  password: 'xxxxx'
  driverClassName: com.mysql.cj.jdbc.Driver
  url: jdbc:mysql://localhost:3306/xxxxx?serverTimezone=Asia/Shanghai&characterEncoding=utf8&useUnicode=true&useSSL=false&autoReconnect=true&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true&nullCatalogMeansCurrent=true

spring:
  datasource:
  	# << 用法解释:引用变量的作用  引用已提前定义好的配置:db-mysql 即最上面的配置
  	# 使用后的配置为:
  	# db-type: mysql
  	# validation-query: SELECT 'x'
  	# filters: stat,wall
  	# username: 'xxxx'
  	# password: 'xxxxx'
  	# driverClassName: com.mysql.cj.jdbc.Driver
  	# url: jdbc:mysql://localhost:3306/xxxxx?serverTimezone=Asia/Shanghai&characterEncoding=utf8&useUnicode=true&useSSL=false&autoReconnect=true&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true&nullCatalogMeansCurrent=true
    <<: *db-mysql

动态数据源配置类

@Configuration
@EnableConfigurationProperties({DynamicDataSourceProperties.class})
@AutoConfigureBefore({DynamicDataSourceAutoConfiguration.class, SpringBootConfiguration.class})
public class DataSourceConfiguration {

    private Logger logger = LoggerFactory.getLogger(this.getClass());

    /**
     * 动态数据源配置项
     */
    @Autowired
    private DynamicDataSourceProperties properties;
    @Autowired
    private DataSourceProperties dataSourceProperties;

    @Bean
    public DynamicDataSourceProvider dynamicDataSourceProvider() {
        //todo 可以做更多的事情,例如从spring容器中获取已创建好的数据源对象,来由动态数据源管理,等等
        
        //默认使用spring提供的数据源信息来创建默认数据源
        DataSourceProperty masterProperty = new DataSourceProperty();
        masterProperty.setType(dataSourceProperties.getType())
            .setDriverClassName(dataSourceProperties.getDriverClassName())
            .setUrl(dataSourceProperties.getUrl())
            .setUsername(dataSourceProperties.getUsername()).setPassword(dataSourceProperties.getPassword());
        //多数据源的数据源信息配置是否存在,如果存在则保存
        Map<String, DataSourceProperty> datasource = properties.getDatasource();
        if(!datasource.isEmpty()){
            //如果存在指定了默认数据源,则替换spring的数据源信息
            DataSourceProperty dynamicMasterProperty = datasource.get(properties.getPrimary());
            if(dynamicMasterProperty != null){
                masterProperty.setType(dynamicMasterProperty.getType())
                    .setDriverClassName(dynamicMasterProperty.getDriverClassName())
                    .setUrl(dynamicMasterProperty.getUrl()).setUsername(dynamicMasterProperty.getUsername())
                    .setPassword(dynamicMasterProperty.getPassword());
            }
        }

        return new CustomDataSourceProvider(masterProperty,properties);
    }

    /**
     * 将动态数据源设置为首选的
     * 当spring存在多个数据源时, 自动注入的是首选的对象
     * 设置为主要的数据源之后,就可以支持shardingjdbc原生的配置方式了
     * @return
     */
    @Primary
    @Bean
    public DataSource dataSource() {
        DynamicRoutingDataSource dataSource = new DynamicRoutingDataSource();
        dataSource.setPrimary(properties.getPrimary());
        dataSource.setStrict(properties.getStrict());
        dataSource.setStrategy(properties.getStrategy());
        dataSource.setP6spy(properties.getP6spy());
        dataSource.setSeata(properties.getSeata());
        return dataSource;
    }
}

继承AbstractDataSourceProvider类,实现loadDataSources方法

@AllArgsConstructor
public class CustomDataSourceProvider extends AbstractDataSourceProvider {

    private final DataSourceProperty masterProperty;
    private final DynamicDataSourceProperties dynamicDataSourceProperties;

    @Override
    public Map<String, DataSource> loadDataSources() {
        Map<String, DataSourceProperty> map = new HashMap(16);
        masterProperty.setDruid(this.dynamicDataSourceProperties.getDruid());
        map.put(this.dynamicDataSourceProperties.getPrimary(), masterProperty);

        Map<String, DataSourceProperty> datasource = this.dynamicDataSourceProperties.getDatasource();
        if (!datasource.isEmpty()) {
            map.putAll(datasource);
        }

        Map<String, DataSource> dataSourceMap = this.createDataSourceMap(map);
        return dataSourceMap;
    }
}
dynamic-datasource-spring-boot-starter 是一个用于在 Spring Boot 应用中实现数据源的开源项目。它提供了简单易用的配置方式和强大的功能,让我们能够轻松地管理和切换多个数据源。 使用 dynamic-datasource-spring-boot-starter 实现数据源的步骤如下: 1. 引入 dynamic-datasource-spring-boot-starter 依赖。在 Maven 或 Gradle 中添加对该项目的依赖,即可将其引入到项目中。 2. 配置多个数据源。在应用的配置文件中,添加多个数据源的配置信息。可以为每个数据源指定不同的 URL、用户名、密码等参数。 3. 配置数据源路由策略。使用 dynamic-datasource-spring-boot-starter 提供的数据源路由策略,将数据源动态地路由到对应的方法或服务上。 4. 使用注解标识数据源。在需要访问不同数据源的方法或服务上,使用相应的注解标识数据源dynamic-datasource-spring-boot-starter 提供了一系列的注解,如 @DataSource、@Master、@Slave 等,用于标识不同的数据源。 5. 运行应用。运行应用后,dynamic-datasource-spring-boot-starter 会根据配置和注解的设置,将请求路由到正确的数据源上。 通过以上步骤,我们就能够轻松地实现数据源的管理和切换。dynamic-datasource-spring-boot-starter 的灵活性和高性能使得在实际项目中使用多数据源变得非常简单和高效。同时,该项目还提供了丰富的监控和调试功能,方便我们对多数据源的运行情况进行监控和优化。总之,dynamic-datasource-spring-boot-starter 是一个强大的工具,为我们实现数据源提供了便捷和可靠的解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值