Spring Boot中的动态数据源切换

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: Spring Boot中的动态数据源切换

Spring Boot中的动态数据源切换

今天,我们将探讨如何在Spring Boot中实现动态数据源切换的技术。动态数据源切换是在多数据源环境下,根据业务需求动态选择数据源的能力,极大地提升了系统的灵活性和扩展性。

引言

随着互联网应用的复杂化,很多系统需要同时操作多个数据库,例如主从库分离、多租户系统等场景。Spring Boot提供了简便的配置和强大的扩展能力,使得实现动态数据源切换成为可能。

技术实现

我们将以一个简单的多数据源切换的例子来说明如何在Spring Boot中实现动态数据源切换。

步骤一:项目初始化

首先,使用Spring Initializr初始化一个新的Spring Boot项目,并添加必要的依赖。

package cn.juwatech.springbootdynamicdatasource;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class SpringBootDynamicDataSourceApplication {
   

    public static void main(String[] args) {
   
        SpringApplication.run(SpringBootDynamicDataSourceApplication.class, args);
    }

}
步骤二:配置多数据源

在application.properties或application.yml中配置多个数据源。

# 数据源1配置
spring.datasource.datasource1.url=jdbc:mysql://localhost:3306/db1
spring.datasource.datasource1.username=root
spring.datasource.datasource1.password=password
spring.datasource.datasource1.driver-class-name=com.mysql.jdbc.Driver

# 数据源2配置
spring.datasource.datasource2.url=jdbc:mysql://localhost:3306/db2
spring.datasource.datasource2.username=root
spring.datasource.datasource2.password=password
spring.datasource.datasource2.driver-class-name=com.mysql.jdbc.Driver
步骤三:动态数据源切换配置

创建动态数据源切换的配置类,并利用Spring的AbstractRoutingDataSource实现动态切换数据源。

package cn.juwatech.springbootdynamicdatasource.config;

import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;

public class DynamicRoutingDataSource extends AbstractRoutingDataSource {
   

    @Override
    protected Object determineCurrentLookupKey() {
   
        return DataSourceContextHolder.getDataSourceType();
    }
}
步骤四:定义数据源上下文

创建一个数据源上下文,用于存储和获取当前线程使用的数据源标识。

package cn.juwatech.springbootdynamicdatasource.config;

public class DataSourceContextHolder {
   

    private static final ThreadLocal<String> contextHolder = new ThreadLocal<>();

    public static void setDataSourceType(String dataSourceType) {
   
        contextHolder.set(dataSourceType);
    }

    public static String getDataSourceType() {
   
        return contextHolder.get();
    }

    public static void clearDataSourceType() {
   
        contextHolder.remove();
    }
}
步骤五:实现动态数据源切换

编写一个AOP切面,在需要切换数据源的地方动态设置数据源标识。

package cn.juwatech.springbootdynamicdatasource.aspect;

import cn.juwatech.springbootdynamicdatasource.config.DataSourceContextHolder;
import cn.juwatech.springbootdynamicdatasource.annotation.DataSource;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;

@Aspect
@Component
@Order(-1)
public class DataSourceAspect {
   

    @Before("@annotation(dataSource)")
    public void beforeSwitchDataSource(DataSource dataSource) {
   
        DataSourceContextHolder.setDataSourceType(dataSource.value());
    }
}
步骤六:使用自定义注解切换数据源

创建一个自定义注解,用于标注需要切换数据源的方法。

package cn.juwatech.springbootdynamicdatasource.annotation;

import java.lang.annotation.*;

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface DataSource {
   

    String value() default "datasource1";
}
步骤七:编写Service层代码

编写一个Service层的示例,演示如何使用自定义注解切换数据源。

package cn.juwatech.springbootdynamicdatasource.service;

import cn.juwatech.springbootdynamicdatasource.annotation.DataSource;
import org.springframework.stereotype.Service;

@Service
public class UserService {
   

    @DataSource("datasource2")
    public void listUsersFromDataSource2() {
   
        // 从数据源2读取用户列表
        // ...
    }

    // 默认使用datasource1
    public void listUsersFromDataSource1() {
   
        // 从数据源1读取用户列表
        // ...
    }
}

结论

通过本文的实例,我们演示了如何在Spring Boot中实现动态数据源切换。动态数据源切换使得在多数据源环境中灵活选择数据源成为可能,非常适用于多租户系统、分布式数据库访问等场景。在实际应用中,可以根据具体需求进一步扩展和优化这个示例,例如增加数据源的动态增删改查能力、集成数据库连接池等。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
前端开发 Java 数据库连接
基于Spring boot轻松实现一个多数据源框架
基于Spring boot轻松实现一个多数据源框架
616 0
|
XML Java 数据库连接
spring管理数据源和引入外部属性文件~
spring管理数据源和引入外部属性文件~
171 0
|
Java 数据库连接 Go
如何在Spring Boot应用中使用Nacos实现动态更新数据源
如何在Spring Boot应用中使用Nacos实现动态更新数据源
1245 0
|
前端开发 Java 数据库连接
Spring Boot 3 整合 Mybatis-Plus 动态数据源实现多数据源切换
Spring Boot 3 整合 Mybatis-Plus 动态数据源实现多数据源切换
|
Java Spring
java202304java学习笔记第六十天-ssm-spring配置文件-spring产生数据源对象2
java202304java学习笔记第六十天-ssm-spring配置文件-spring产生数据源对象2
150 0
java202304java学习笔记第六十天-ssm-spring配置文件-数据源开发步骤
java202304java学习笔记第六十天-ssm-spring配置文件-数据源开发步骤
109 0
|
设计模式 Java 数据库连接
【Spring源码】JDBC数据源访问实现
我们再来看看阅读线索三,这方面我们从设计模式进行入手。阅读线索三:从这个模块可以学到什么我们看下以下代码,PreparedStatement实例的是由PreparedStatementCreator实现的。再来看看PreparedStatementCreator接口,一共有三个子类实现。也就是说PreparedStatement的三种不同实现被封装到三个子类中,而具体需要哪种实现,只需要传入不同。
244 1
【Spring源码】JDBC数据源访问实现
|
Java Spring
spring基于注解配置数据源
spring基于注解配置数据源
136 0
|
Java 数据库连接 数据库
【Spring技术专题】「实战开发系列」保姆级教你SpringBoot整合Mybatis框架实现多数据源的静态数据源和动态数据源配置落地
Mybatis是一个基于JDBC实现的,支持普通 SQL 查询、存储过程和高级映射的优秀持久层框架,去掉了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索封装。 Mybatis主要思想是将程序中大量的 SQL 语句剥离出来,配置在配置文件中,以实现 SQL 的灵活配置。在所有 ORM 框架中都有一个非常重要的媒介——PO(持久化对象),PO 的作用就是完成持久化操作,通过该对象对数据库执行增删改的操作,以面向对象的方式操作数据库。
455 1
【Spring技术专题】「实战开发系列」保姆级教你SpringBoot整合Mybatis框架实现多数据源的静态数据源和动态数据源配置落地
|
druid Java 关系型数据库
Spring案例:数据源对象管理及加载properties文件
Spring案例:数据源对象管理及加载properties文件
221 0