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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • IDEA进程已结束,退出代码-1073741819 (0xC0000005)的bug

    IDEA进程已结束,退出代码-1073741819 (0xC0000005)的bug

    这篇文章主要介绍了IDEA进程已结束,退出代码-1073741819 (0xC0000005)的bug,本文通过实例代码图文的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-04-04
  • Java分布式学习之Kafka消息队列

    Java分布式学习之Kafka消息队列

    Kafka是由Apache软件基金会开发的一个开源流处理平台,由Scala和Java编写。Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者在网站中的所有动作流数据
    2022-07-07
  • Java Map的排序实例详解

    Java Map的排序实例详解

    这篇文章主要介绍了 Java Map的排序实例详解的相关资料,希望通过本文大家能够掌握map的排序,需要的朋友可以参考下
    2017-09-09
  • netty中的IO、NIO、AIO使用详解

    netty中的IO、NIO、AIO使用详解

    这篇文章主要介绍了netty中的IO、NIO、AIO使用详解,本文会说明各种IO的特点、分别解决了什么样的问题做一个分析阐述,并结合Java代码例子来辅助理解,像这些的历史演进和详细的底层原理网上很多,所以我们只站在应用层,使用者的角度去分析,需要的朋友可以参考下
    2023-12-12
  • Spring自定义注解实现接口版本管理

    Spring自定义注解实现接口版本管理

    这篇文章主要介绍了Spring自定义注解实现接口版本管理,RequestMappingHandlerMapping类是与 @RequestMapping相关的,它定义映射的规则,即满足怎样的条件则映射到那个接口上,需要的朋友可以参考下
    2023-11-11
  • java开发中使用IDEA活动模板快速增加注释的方法

    java开发中使用IDEA活动模板快速增加注释的方法

    这篇文章主要介绍了java开发中使用IDEA活动模板快速增加注释,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • Java中的动态代理和静态代理详细解析

    Java中的动态代理和静态代理详细解析

    这篇文章主要介绍了Java中的动态代理和静态代理详细解析,Java中的代理可以帮助被代理者完成一些前期的准备工作和后期的善后工作,但是核心的业务逻辑仍然是由被代理者完成,需要的朋友可以参考下
    2023-11-11
  • MyBatis框架零基础快速入门案例详解

    MyBatis框架零基础快速入门案例详解

    MyBatis本是apache的一个开源项目iBatis,2010年这个项目由apache software foundation迁移到了google code,并且改名为MyBatis。2013年11月迁移到Github。iBATIS一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架
    2022-04-04
  • java+jsp+struts2实现发送邮件功能

    java+jsp+struts2实现发送邮件功能

    这篇文章主要为大家详细介绍了java+jsp+struts2实现发送邮件功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • Java实现数组翻转的实现代码

    Java实现数组翻转的实现代码

    这篇文章主要介绍了Java实现数组翻转的实现代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09

最新评论