Spring Boot 双数据源配置

文章目录

什么是双数据源?

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

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

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

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

为什么需要双数据源?

1. 业务分离

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

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

2. 性能优化

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

3. 数据安全

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

核心实现原理

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

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

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

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

完整示例

https://github.com/yikousu/DataSwitch

注意

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

解决方案:

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

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

相关推荐
杜子不疼.12 小时前
计算机视觉热门模型手册:Spring Boot 3.2 自动装配新机制:@AutoConfiguration 使用指南
人工智能·spring boot·计算机视觉
indexsunny14 小时前
互联网大厂Java求职面试实战:Spring Boot微服务与Redis缓存场景解析
java·spring boot·redis·缓存·微服务·消息队列·电商
无心水14 小时前
【分布式利器:腾讯TSF】7、TSF高级部署策略全解析:蓝绿/灰度发布落地+Jenkins CI/CD集成(Java微服务实战)
java·人工智能·分布式·ci/cd·微服务·jenkins·腾讯tsf
28岁青春痘老男孩19 小时前
JDK8+SpringBoot2.x 升级 JDK 17 + Spring Boot 3.x
java·spring boot
方璧19 小时前
限流的算法
java·开发语言
元Y亨H19 小时前
Nacos - 服务注册
java·微服务
曲莫终20 小时前
Java VarHandle全面详解:从入门到精通
java·开发语言
天若有情67320 小时前
校园二手交易系统实战开发全记录(vue+SpringBoot+MySQL)
vue.js·spring boot·mysql
一心赚狗粮的宇叔20 小时前
中级软件开发工程师2025年度总结
java·大数据·oracle·c#
while(1){yan}20 小时前
MyBatis Generator
数据库·spring boot·java-ee·mybatis