Spring Boot 双数据源配置及实现原理

 更新时间:2025年07月22日 11:16:21   作者:一口酥Hac  
双数据源指应用同时连接两个数据库,实现业务分离、性能优化及数据安全,Spring通过AbstractRoutingDataSource动态切换数据源,结合AOP设置键值,需注意@Transactional无法跨数据源,建议使用分布式事务框架,本文给大家介绍Spring Boot双数据源配置,感兴趣的朋友一起看看吧

Spring Boot配置和使用两个数据源的实现步骤

什么是双数据源?

双数据源是指在一个应用程序中同时配置和使用两个不同的数据库连接。比如:

  • 一个连接订单数据库,处理业务数据
  • 一个连接用户中心数据库,处理用户信息

这样的架构设计可以实现数据隔离、业务分离,提升系统的可维护性和扩展性。

实现原理基于 AbstractRoutingDataSource 动态切换。

为什么需要双数据源?

1. 业务分离
不同的业务模块使用独立的数据库,职责更加明确:

订单系统 → 订单数据库(存储订单、商品、支付信息)
用户系统 → 用户数据库(存储用户、权限、组织信息)

2. 性能优化

  • 分散数据库负载,避免单点压力
  • 可以针对不同业务特点优化数据库配置

3. 数据安全

  • 敏感数据隔离存储
  • 不同数据源可以设置不同的访问权限

核心实现原理

双数据源的核心是 Spring 的 AbstractRoutingDataSource(用于动态切换数据源),它可以根据某个键值动态选择不同的数据源:

Spring 每次访问数据库前,都会先执行 determineCurrentLookupKey方法 来判断用哪个数据源。我们通过 AOP 切面,在执行方法前设置好对应的数据源,就能实现动态切换。

配置好双数据源后,访问另一个数据库的方式和访问本地数据库几乎一样,开发时感知不到差异。

public class DynamicDataSource extends AbstractRoutingDataSource {
    @Override
    protected Object determineCurrentLookupKey() {
        // 返回当前线程需要使用的数据源标识
        return DataSourceContextHolder.getDataSourceType();
    }
}

完整示例

https://github.com/yikousu/DataSwitch

注意

普通的 @Transactional 注解无法跨数据源生效!

解决方案:

  • 推荐:同一业务尽量只操作一个数据源

  • 如必须跨库:考虑使用分布式事务框架

到此这篇关于Spring Boot 双数据源配置的文章就介绍到这了,更多相关Spring Boot 双数据源内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java Volatile关键字你真的了解吗

    Java Volatile关键字你真的了解吗

    这篇文章主要为大家介绍了Java Volatile关键字,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-12-12
  • Java代理模式(Proxy)实现方法详解

    Java代理模式(Proxy)实现方法详解

    这篇文章主要介绍了Java代理模式(Proxy)实现的相关资料,代理模式是一种结构型设计模式,通过引入代理对象来控制对目标对象的访问,代理模式的优点包括职责清晰、扩展性好、保护目标对象和增强功能,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-04-04
  • Java CAS与Atomic原子操作核心原理详解

    Java CAS与Atomic原子操作核心原理详解

    CAS(Compare and Swap)和Atomic原子操作是保证多线程并发安全的常用机制,能够高效地实现对共享变量的安全访问和修改,避免线程竞争导致的数据不一致和死锁等问题。它们的应用可以提高程序的并发性能和可维护性,是多线程编程中的重要工具
    2023-04-04
  • dubbo3 filter(过滤器)如何自定义过滤器

    dubbo3 filter(过滤器)如何自定义过滤器

    dubbo3filter(过滤器)类似于javaweb中的filter和springmvc中的intercaptor,用于在请求发送前或到达前进行预处理工作,完成限流和监控,在dubbo中,过滤器运行在consumer和provider两端,分别在调用链中执行
    2025-03-03
  • 面试官:详细谈谈Java对象的4种引用方式

    面试官:详细谈谈Java对象的4种引用方式

    这篇文章主要给大家介绍了java面试官常会问到的,关于Java对象的4种引用方式的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Java具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • SpringMVC JSON数据交互及RESTful支持实现方法

    SpringMVC JSON数据交互及RESTful支持实现方法

    这篇文章主要介绍了SpringMVC JSON数据交互及RESTful支持实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • MyBatis标签之Select resultType和resultMap详解

    MyBatis标签之Select resultType和resultMap详解

    这篇文章主要介绍了MyBatis标签之Select resultType和resultMap,在MyBatis中有一个ResultMap标签,它是为了映射select标签查询出来的结果集,下面使用一个简单的例子,来介绍 resultMap 的使用方法,需要的朋友可以参考下
    2022-09-09
  • SpringSecurity 表单登录的实现

    SpringSecurity 表单登录的实现

    本文主要介绍了SpringSecurity 表单登录的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • Geotools实现shape文件的写入功能

    Geotools实现shape文件的写入功能

    Geotools作为开源的Java GIS三方库,已经成为GIS服务器端的主流开源库,其功能非常强大,涉及到GIS业务的方方面面,其中就包括GIS数据的读写,今天小编就借助Geotools来实现shape数据的写入,需要的朋友可以参考下
    2023-08-08
  • javaWeb实现学生信息管理系统

    javaWeb实现学生信息管理系统

    这篇文章主要为大家详细介绍了javaWeb实现学生信息管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01

最新评论