springboot项目实现多数据源配置使用dynamic-datasource-spring-boot-starter的操作步骤

 更新时间:2023年06月10日 14:52:08   作者:无聊大侠hello world  
这篇文章主要介绍了springboot项目实现多数据源配置使用dynamic-datasource-spring-boot-starter,本文分步骤结合实例代码给大家介绍的非常详细,需要的朋友可以参考下

要在Spring Boot项目中使用 dynamic-datasource-spring-boot-starter 实现多数据源配置,可以按照以下步骤进行操作:

1.添加依赖:

在项目的 pom.xml 文件中添加 dynamic-datasource-spring-boot-starter 依赖:

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

2.配置数据源:

在项目的配置文件(application.propertiesapplication.yml)中配置多个数据源,例如:

dynamic:
  datasource:
    names: primary, secondary
    primary:
      driver-class-name: com.mysql.cj.jdbc.Driver
      url: jdbc:mysql://localhost:3306/db1?useSSL=false&serverTimezone=UTC
      username: root
      password: password1
    secondary:
      driver-class-name: com.mysql.cj.jdbc.Driver
      url: jdbc:mysql://localhost:3306/db2?useSSL=false&serverTimezone=UTC
      username: root
      password: password2

3.配置数据源切换策略:
创建一个配置类,用于配置数据源切换策略。例如,可以使用 RoundRobinRoutingDataSourceLoadBalanceDataSource 进行数据源的轮询切换或负载均衡切换。示例代码如下:

@Configuration
public class DataSourceConfig 
{
    @Autowired
    private DataSourceProperties dataSourceProperties;
    @Bean
    @ConfigurationProperties(prefix = "dynamic.datasource")
    public DataSource dataSource() 
    {
        return DataSourceBuilder.create().build();
    }
    @Bean
    @Primary
    public DataSourceProvider dataSourceProvider()
    {
        DataSourceProperties.DataSourceType defaultDataSourceType = dataSourceProperties.getType();
        Map<String, DataSource> dataSources = new HashMap<>();
        dataSources.put("primary", dataSourceProperties.getPrimary());
        dataSources.put("secondary", dataSourceProperties.getSecondary());
        DynamicDataSourceProvider dynamicDataSourceProvider = new DynamicDataSourceProvider();
        dynamicDataSourceProvider.setDefaultDataSourceType(defaultDataSourceType);
        dynamicDataSourceProvider.setDataSources(dataSources);
        return dynamicDataSourceProvider;
    }
    @Bean
    public DynamicDataSource dynamicDataSource(DataSourceProvider dataSourceProvider)
    {
        DynamicDataSource dynamicDataSource = new DynamicDataSource();
        dynamicDataSource.setDataSourceProvider(dataSourceProvider);
        return dynamicDataSource;
    }
    @Bean
    public DataSourceTransactionManager transactionManager(DynamicDataSource dynamicDataSource)
    {
        return new DataSourceTransactionManager(dynamicDataSource);
    }
    @Bean
    public SqlSessionFactory sqlSessionFactory(DynamicDataSource dynamicDataSource) throws Exception 
    {
        SqlSessionFactoryBean sessionFactoryBean = new SqlSessionFactoryBean();
        sessionFactoryBean.setDataSource(dynamicDataSource);
        return sessionFactoryBean.getObject();
    }
}

4.使用数据源:

在需要使用不同数据源的地方,可以使用 @DS 注解指定要使用的数据源,例如:

@Service
public class UserService 
{
    @Autowired
    private UserMapper userMapper;
    @DS("primary")
    public User getPrimaryUserById(Long id) 
    {
        return userMapper.selectById(id);
    }
    @DS("secondary")
    public User getSecondaryUserById(Long id)
    {
        return userMapper.selectById(id);
    }
}

以上是使用 dynamic-datasource-spring-boot-starter 实现多数据源配置的基本步骤和示例代码。通过这样的配置,可以轻松地在Spring Boot项目中使用多个数据源进行数据库操作。

到此这篇关于springboot项目实现多数据源配置使用dynamic-datasource-spring-boot-starter的文章就介绍到这了,更多相关springboot使用dynamic-datasource-spring-boot-starter内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Spring Boot 接口加解密功能实现

    Spring Boot 接口加解密功能实现

    在我们日常的Java开发中,免不了和其他系统的业务交互,或者微服务之间的接口调用;如果我们想保证数据传输的安全,对接口出参加密,入参解密,这篇文章主要介绍了Spring Boot 接口加解密功能实现,需要的朋友可以参考下
    2023-04-04
  • Storm框架整合springboot的方法

    Storm框架整合springboot的方法

    Storm框架中的每个Spout和Bolt都相当于独立的应用,Strom在启动spout和bolt时提供了一个open方法(spout)和prepare方法(bolt)。这篇文章主要介绍了Storm框架整合springboot的方法,需要的朋友可以参考下
    2018-11-11
  • Thymeleaf渲染网页时中文乱码的问题及解决

    Thymeleaf渲染网页时中文乱码的问题及解决

    这篇文章主要介绍了Thymeleaf渲染网页时中文乱码的问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • Java大数据开发Hadoop MapReduce

    Java大数据开发Hadoop MapReduce

    MapReduce的思想核心是“分而治之”,适用于大量复杂的任务处理场景(大规模数据处理场景)Map负责“分”,即把复杂的任务分解为若干个“简单的任务”来并行处理。可以进行拆分的前提是这些小任务可以并行计算,彼此间几乎没有依赖关系
    2023-03-03
  • java通过ip获取客户端Mac地址的小例子

    java通过ip获取客户端Mac地址的小例子

    java通过ip获取客户端Mac地址的小例子,需要的朋友可以参考一下
    2013-03-03
  • JUnit5常用注解的使用

    JUnit5常用注解的使用

    注解是JUnit的标志性技术,本文就来对它的20个注解,以及元注解和组合注解进行学习,感兴趣的可以了解一下
    2021-07-07
  • SpringBoot后端服务重定向的实现示例

    SpringBoot后端服务重定向的实现示例

    本文主要介绍了SpringBoot后端服务重定向的实现示例,通过重定向、路径匹配、反向代理和直接调用Controller层接口等方法来实现,感兴趣的可以了解一下
    2025-01-01
  • 关于Java实现word(docx、doc)转html的完美解决方案

    关于Java实现word(docx、doc)转html的完美解决方案

    文章介绍了多种将Word文档转换为HTML的方法,包括使用Microsoft Word自带的导出功能、第三方工具和编程实现,展示了如何实现将.docx文件转换为HTML文件,并自动生成目录、处理分页符和增强表格样式等功能,感兴趣的朋友一起看看吧
    2025-01-01
  • Spring的@Configuration使用与原理

    Spring的@Configuration使用与原理

    这篇文章主要介绍了Spring的@Configuration使用与原理,@Configuration用于定义配置类,可替换xml配置文件,被注解的类内部包含有一个或多个被@Bean注解的方法,需要的朋友可以参考下
    2023-05-05
  • 详解Spring与Mybatis整合方法(基于IDEA中的Maven整合)

    详解Spring与Mybatis整合方法(基于IDEA中的Maven整合)

    这篇文章主要介绍了Spring与Mybatis整合方法(基于IDEA中的Maven整合),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10

最新评论