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

本文主要是介绍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-mysqlusername: 'xxxx'password: 'xxxxx'driverClassName: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://localhost:3306/xxxxx?serverTimezone=Asia/Shanghai&characterEncoding=utf8&useUnicode=true&useSSL=false&autoReconnect=true&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true&nullCatalogMeansCurrent=truespring: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());/*** 动态数据源配置项*/@Autowiredprivate DynamicDataSourceProperties properties;@Autowiredprivate DataSourceProperties dataSourceProperties;@Beanpublic 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@Beanpublic 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;@Overridepublic 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;}
}

这篇关于Springboot 集成 dynamic-datasource-spring-boot-starter,实现项目中原有的数据源作为主数据源的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/876069

相关文章

springboot rocketmq配置生产者和消息者的步骤

《springbootrocketmq配置生产者和消息者的步骤》本文介绍了如何在SpringBoot中集成RocketMQ,包括添加依赖、配置application.yml、创建生产者和消费者,并展... 目录1. 添加依赖2. 配置application.yml3. 创建生产者4. 创建消费者5. 使用在

Spring Retry 实现乐观锁重试实践记录

《SpringRetry实现乐观锁重试实践记录》本文介绍了在秒杀商品SKU表中使用乐观锁和MybatisPlus配置乐观锁的方法,并分析了测试环境和生产环境的隔离级别对乐观锁的影响,通过简单验证,... 目录一、场景分析 二、简单验证 2.1、可重复读 2.2、读已提交 三、最佳实践 3.1、配置重试模板

Spring中@Lazy注解的使用技巧与实例解析

《Spring中@Lazy注解的使用技巧与实例解析》@Lazy注解在Spring框架中用于延迟Bean的初始化,优化应用启动性能,它不仅适用于@Bean和@Component,还可以用于注入点,通过将... 目录一、@Lazy注解的作用(一)延迟Bean的初始化(二)与@Autowired结合使用二、实例解

SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)

《SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)》本文介绍了如何在SpringBoot项目中使用Jasypt对application.yml文件中的敏感信息(如数... 目录SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)前言一、J

Java中有什么工具可以进行代码反编译详解

《Java中有什么工具可以进行代码反编译详解》:本文主要介绍Java中有什么工具可以进行代码反编译的相关资,料,包括JD-GUI、CFR、Procyon、Fernflower、Javap、Byte... 目录1.JD-GUI2.CFR3.Procyon Decompiler4.Fernflower5.Jav

Spring Boot 中正确地在异步线程中使用 HttpServletRequest的方法

《SpringBoot中正确地在异步线程中使用HttpServletRequest的方法》文章讨论了在SpringBoot中如何在异步线程中正确使用HttpServletRequest的问题,... 目录前言一、问题的来源:为什么异步线程中无法访问 HttpServletRequest?1. 请求上下文与线

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

Java对象和JSON字符串之间的转换方法(全网最清晰)

《Java对象和JSON字符串之间的转换方法(全网最清晰)》:本文主要介绍如何在Java中使用Jackson库将对象转换为JSON字符串,并提供了一个简单的工具类示例,该工具类支持基本的转换功能,... 目录前言1. 引入 Jackson 依赖2. 创建 jsON 工具类3. 使用示例转换 Java 对象为

SpringBoot快速接入OpenAI大模型的方法(JDK8)

《SpringBoot快速接入OpenAI大模型的方法(JDK8)》本文介绍了如何使用AI4J快速接入OpenAI大模型,并展示了如何实现流式与非流式的输出,以及对函数调用的使用,AI4J支持JDK8... 目录使用AI4J快速接入OpenAI大模型介绍AI4J-github快速使用创建SpringBoot

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx