数据库读取数据源配置实现动态数据源

本文介绍了在大型微服务项目中如何管理大量数据源。通过数据库存储数据源配置,避免配置文件臃肿,利用SpringBoot、Druid和AOP实现动态数据源路由。设计了数据源配置表,并详细阐述了数据源的创建、缓存、AOP切面以及动态设置数据源key的两种方式,包括注解和参数传递。整个流程确保了服务的灵活性和高可用性。

概述

项目中整合多数据源时,一般是通过读取配置文件中的数据源信息创建数据源 放到AbstractRoutingDataSource的targetDataSources的map中, 然后通过AbstractRoutingDataSource获取实际需要的数据源。

当项目中需要整合的数据源特别多的时候,比如:8个、16个、32个数据库等, 这个时候配置文件就会变得比较臃肿,而且现在主流的是微服务架构, 可能一套服务有多个模块,如果是通过配置文件进行配置,那么需要 修改的配置文件相对较多,这种情况可以通过数据库进行配置数据源 或者是通过配置中心进行配置。

下面将演示通过数据库配置所有的数据源,服务只需要配置默认的数据源, 通过默认的数据源读取配置的多数据源,然后创建数据源实例,最后将 创建的数据源实例放在AbstractRoutingDataSource中。

环境说明

  • spring boot
  • mysql
  • mybatis-plus
  • spring-aop
  • druid
  • redis

项目目录结构

  • controller: 存放接口类
  • service: 存放服务类
  • mapper: 存放操作数据库的mapper接口
  • model: 存放数据库表实体类
  • vo: 存放返回给前端的视图类

  • context: 线程公共上下文
  • config: 数据源配置信息
  • annotation: 实现动态数据源加载自定义注解
  • aop: 实现动态数据源设置切面类
  • util: 工具类
  • constants: 常量类

关键类说明

  • SpringContextUtils: 获取手动获取Spring容器中的bean, 包含ApplicationContext属性
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值