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

相关文章

  • springboot 中 inputStream 神秘消失之谜(终破)

    springboot 中 inputStream 神秘消失之谜(终破)

    这篇文章主要介绍了springboot 中 inputStream 神秘消失之谜,为了能够把这个问题说明,我们首先需要从简单的http调用说起,通过设置body等一些操作,具体实现代码跟随小编一起看看吧
    2021-08-08
  • SpringBoot3 RestTemplate配置与使用详解

    SpringBoot3 RestTemplate配置与使用详解

    本文详细介绍了在 SpringBoot 3.x 中如何配置和使用 RestTemplate,包括基本配置、高级配置以及各种使用场景,感兴趣的朋友跟随小编一起看看吧
    2024-12-12
  • SpringBoot集成Mybatis并测试

    SpringBoot集成Mybatis并测试

    这篇文章主要介绍了SpringBoot集成Mybatis并测试,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • Java中synchronized的优化措施

    Java中synchronized的优化措施

    这篇文章主要介绍了Java中synchronized的优化,介绍为了实现高效并发,虚拟机对synchronized 做的一系列的锁优化措施,本文给大家介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • 解决IDEA中Maven依赖包导入失败报红问题(总结最有效8种解决方案)

    解决IDEA中Maven依赖包导入失败报红问题(总结最有效8种解决方案)

    这篇文章主要介绍了解决IDEA中Maven依赖包导入失败报红问题,本文通过图文详解给大家总结了最有效的8种解决方法,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07
  • java通过ip获取客户端Mac地址的小例子

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

    java通过ip获取客户端Mac地址的小例子,需要的朋友可以参考一下
    2013-03-03
  • springboot启动不了也不报错的问题及解决

    springboot启动不了也不报错的问题及解决

    这篇文章主要介绍了springboot启动不了也不报错的问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • Reactive反应式编程及使用介绍

    Reactive反应式编程及使用介绍

    这篇文章主要介绍了为什使用Reactive反应式编程的原因分析,有需要的朋友可以借鉴参考下,希望能够有所帮助祝大家多多进步,早日升职加薪
    2022-02-02
  • java 用itext设置pdf纸张大小操作

    java 用itext设置pdf纸张大小操作

    这篇文章主要介绍了java 用itext设置pdf纸张大小操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • 基于Spire.Doc for Java实现HTML转PDF的操作方案

    基于Spire.Doc for Java实现HTML转PDF的操作方案

    本文记录了使用Spire.DocforJava将HTML内容转换为PDF文档的过程,包括环境准备、两种常见的转换场景、进阶设置以及注意事项,适用于样式复杂度相对可控、排版以文档流为主的转换需求,需要的朋友可以参考下
    2026-04-04

最新评论