当前位置: 首页 > news >正文

SpringBoot动态数据源实现

一、背

一个应用难免需要连接多个数据库,像我们系统起码连接了5个以上数据库,AWS RDS主库,ECS自搭MySQL从库,工厂系统三个SQLServer数据库,在线网站MySQL数据库,记得很早以前是用SessionFactory配置(只有模糊的印象了),  下面介绍一下在Spring boot通过AOP的方式实现动态数据源切换。

二、基础知识点

1、AbstractRoutingDataSource

AbstractRoutingDataSource是Spring-jdbc提供一个继承自AbstractDataSource的抽象类。

AbstractRoutingDataSource 关键属性

  • targetDataSources:存放Key和数据库连接映射关系

  • defaultTargetDataSource:  默认连接

  • resolvedDataSources:这个数据是通过targetDataSources构建而成,也是存放Key和数据库连接映射关系。

AbstractRoutingDataSource 关键方法

  • afterPropertiesSet:在初始化Bean时就会执行,将外部传入的targetDataSources构建为内部的resolvedDataSources。

  • determineTargetDataSource:获取数据库连接getConnection方法会调用determineTargetDataSource来创建连接,它决定Spring容器使用的是哪一个连接。

  • determineCurrentLookupKey:抽像方法,一个扩展点,由子类实现,获取连接标识。

2、DynamicDataSource

          自定义动态数据源类

  • 继承AbstractRoutingDataSource

  • 用ThreadLocal<String>存放当前线程的数据源标识

  •  实现determineCurrentLookupKey方法获得当前数据源标记

3、DataSourceAspect

利用AOP进行数据源切换,DataSourceAspect类会去获取Service方法上的注解,如果没有注解则使用默认数据源,否则得到注解上的name,调用DynamicDataSource将数据源标识设置进去,然后调用Service方法该线程就使用该数据源。

三、实现代码

1、application.properties

2、DynamicDataSource 自定义动态数据源类

图片

3、DataSourceConfig 数据源配置类

将数据源配置注入到DynamicDataSource类

4、DataSourceNames 数据源注解名定义

5、DataSourceAspect 

6、业务类

http://www.lryc.cn/news/327677.html

相关文章:

  • 计算机网络常见题(持续更新中~)
  • 富格林:可信招数揭发防备暗箱陷阱
  • 获取高德安全码SHA1
  • 关于RPC
  • pulsar: kafka on pulsar之把pulsar当kafka用
  • 七月论文审稿GPT第4版:通过paper-review数据集微调Mixtral-8x7b
  • 基于 YOLO V8 Fine-Tuning 训练自定义的目标检测模型
  • 快手,得物,蓝月亮,蓝禾,奇安信,三七互娱,顺丰,康冠科技,金证科技24春招内推
  • 全局UI方法-弹窗二-列表选择弹窗(ActionSheet)
  • Memcached分布式内存对象数据库
  • 华为广告打包报错,问题思考
  • docker-compose mysql
  • PGAdmin 4:用于管理和维护PostgreSQL数据库的强大工具
  • 成都市酷客焕学新媒体科技有限公司:实现品牌的更大价值!
  • 探索数据库--------------mysql主从复制和读写分离
  • 【Hello,PyQt】控件拖拽
  • 荟萃分析R Meta-Analyses 3 Effect Sizes
  • 常用的8个应用和中间件的Docker运行示例
  • UnoCSS实现背景图片样式加载
  • vue前端工程化
  • 面向对象:继承
  • ES学习日记(一)-------单节点安装启动
  • 【管理咨询宝藏59】某大型汽车物流战略咨询报告
  • ArcGIS Pro横向水平图例
  • 线程创建的几种方式
  • Python教程:一文掌握Python多线程(很详细)
  • 华为防火墙配置指引超详细(包含安全配置部分)以USG6320为例
  • (含react-draggable库以及相关BUG如何解决)固定在左上方某盒子内(如按钮)添加可拖动功能,使用react hook语法实现
  • 选择最佳图像处理工具OpenCV、JAI、ImageJ、Thumbnailator和Graphics2D
  • 微信小程序版本更新检测