当前位置:首页 > 科技  > 软件

一个注解搞定多数据源切换,你学会了吗?

来源: 责编: 时间:2023-11-28 09:36:31 383观看
导读我们都知道,再开发的过程中,对于多个数据库,就会有各种各样的数据源,比如Oracle,比如 Mysql,并且再开发的过程中,我们很有可能会同时使用到两个数据库,这样就设计到了切换不同的数据源来进行实现,就比如我们在 Oracle 的数据

我们都知道,再开发的过程中,对于多个数据库,就会有各种各样的数据源,比如Oracle,比如 Mysql,并且再开发的过程中,我们很有可能会同时使用到两个数据库,这样就设计到了切换不同的数据源来进行实现,就比如我们在 Oracle 的数据库中去查询一些必要的数据,然后让这些源头数据进入到 Mysql ,这个时候,如果不通过第三方的工具,比如 dataWorks或者其他的组件的话, 那么就得通过 Java 代码来进行实现了,今天了不起就来给大家介绍一下这个关于这个一个注解就切换数据源的操作。Vsx28资讯网——每日最新资讯28at.com

数据源

数据源的意思是“数据库应用程序所使用的数据库或者数据库服务器”;数据源也即数据的来源,是提供某种所需要数据的器件或原始媒体,在数据源中存储了所有建立数据库连接的信息,通过提供正确的数据源名称,可以找到相应的数据库连接。Vsx28资讯网——每日最新资讯28at.com

@DS

我们先来看看这个注解的使用Vsx28资讯网——每日最新资讯28at.com

<!--配置多数据源-->        <dependency>            <groupId>com.baomidou</groupId>            <artifactId>dynamic-datasource-spring-boot-starter</artifactId>            <version>3.5.0</version>        </dependency>

修改YML 的配置如下Vsx28资讯网——每日最新资讯28at.com

datasource:    dynamic:      druid:        initial-size: 5        min-idle: 5        maxActive: 20        # 配置获取连接等待超时的时间        maxWait: 60000        # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒        timeBetweenEvictionRunsMillis: 6000        # 配置一个连接在池中最小生存的时间,单位是毫秒        minEvictableIdleTimeMillis: 60000        # 配置一个连接在池中最大生存的时间,单位是毫秒        maxEvictableIdleTimeMillis: 900000        validationQuery: SELECT 1 FROM DUAL        testWhileIdle: true        testOnBorrow: false        testOnReturn: false        # 打开PSCache,并且指定每个连接上PSCache的大小        poolPreparedStatements: true        maxPoolPreparedStatementPerConnectionSize: 20      primary: master #设置默认的数据源或者数据源组,默认值即为master      strict: false #严格匹配数据源,默认false. true未匹配到指定数据源时抛异常,false使用默认数据源      datasource:        master:          driver-class-name: com.mysql.cj.jdbc.Driver # 3.2.0开始支持SPI可省略此配置          url: jdbc:mysql://localhost:3306/table1?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf-8&useSSL=false&allowMultiQueries=true&allowPublicKeyRetrieval=true          username: xxxx          password: xxxxx        slave_1:          driver-class-name: com.mysql.cj.jdbc.Driver # 3.2.0开始支持SPI可省略此配置          url: jdbc:mysql://localhost:3306/table2?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf-8&useSSL=false&allowMultiQueries=true&allowPublicKeyRetrieval=true          username: xxxx          password: xxxxx

注意这个 dynamic 一定是我们引入的 mybatis 当中的,这个时候,如果我们去使用这个@DS注解的话,那么就可以去切换数据源,比如我们在配置文件中,配置了 master  还有一个 slave_1 的数据源,那么你在使用的时候,可以这样,在我们的方法,或者类上面Vsx28资讯网——每日最新资讯28at.com

@DS("slave_1")

这个注解,你可以使用在你的方法上面,你也可以使用在你的类上面,(一般是用在mapper、service),使用过该注解的方法即可操作到对应的数据源。既然我们知道怎么去使用这个注解了,那么就得来看看这个源码的部分了。Vsx28资讯网——每日最新资讯28at.com

图片图片Vsx28资讯网——每日最新资讯28at.com

首先mybatis-plus使用com.baomidou.dynamic.datasource.AbstractRoutingDataSource继承 AbstractDataSource接管数据源;Vsx28资讯网——每日最新资讯28at.com

具体实现类(ctrl+alt+b可以查看抽象类或者的具体实现类)为com.baomidou.dynamic.datasource.DynamicRoutingDataSource。项目初始化调用public synchronized void addDataSource(String ds, DataSource dataSource)加载数据源,数据源存进dataSourceMap中。Vsx28资讯网——每日最新资讯28at.com

图片图片Vsx28资讯网——每日最新资讯28at.com

当我们发送具体的操作请求的时候,进行数据操作时,方法会被com.baomidou.dynamic.datasource.aop.DynamicDataSourceAnnotationInterceptor拦截Vsx28资讯网——每日最新资讯28at.com

图片图片Vsx28资讯网——每日最新资讯28at.com

拦截器首先从被拦截的方法或者类(一般@DS注解用于Service,也可用于Mapper和Controller)上寻找@DS注解,获取到@DS注解的值后将其存入com.baomidou.dynamic.datasource.toolkit.DynamicDataSourceContextHolder;DynamicDataSourceContextHolder使用ThreadLocal存储当前线程的数据源名。Vsx28资讯网——每日最新资讯28at.com

进行数据操作时,会调用org.springframework.jdbc.datasource.getConnection()方法;Vsx28资讯网——每日最新资讯28at.com

getConnection()方法最终调用了com.baomidou.dynamic.datasource.AbstractRoutingDataSource的getConnection()方法;Vsx28资讯网——每日最新资讯28at.com

数据操作完成后,方法返回第二步中的拦截器,执行DynamicDataSourceContextHolder.poll();清除掉此次Threadlocal中的数据源,避免影响后续数据操作。Vsx28资讯网——每日最新资讯28at.com

但是还有一个问题了,那就是不可在事务中切换数据库,保证事务需要方法使用同一连接,使用@DS(dataSourceOne)方法调用@DS(dataSourceTwo)无法切换连接,会导致方法报错。Vsx28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-34656-0.html一个注解搞定多数据源切换,你学会了吗?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 不少人面试都挂在这道题了!你挂了吗?

下一篇: Springboot扩展点之BeanDefinitionRegistryPostProcessor,你学会了吗?

标签:
  • 热门焦点
  • 7月安卓手机性价比榜:努比亚+红魔两款新机入榜

    7月登场的新机有努比亚Z50S Pro和红魔8S Pro,除了三星之外目前唯二的两款搭载超频版骁龙8Gen2处理器的产品,而且努比亚和红魔也一贯有着不错的性价比,所以在本次的性价比榜单
  • SpringBoot中使用Cache提升接口性能详解

    环境:springboot2.3.12.RELEASE + JSR107 + Ehcache + JPASpring 框架从 3.1 开始,对 Spring 应用程序提供了透明式添加缓存的支持。和事务支持一样,抽象缓存允许一致地使用各
  • 三万字盘点 Spring 九大核心基础功能

    大家好,我是三友~~今天来跟大家聊一聊Spring的9大核心基础功能。话不多说,先上目录:图片友情提示,本文过长,建议收藏,嘿嘿嘿!一、资源管理资源管理是Spring的一个核心的基础功能,不
  • JVM优化:实战OutOfMemoryError异常

    一、Java堆溢出堆内存中主要存放对象、数组等,只要不断地创建这些对象,并且保证 GC Roots 到对象之间有可达路径来避免垃 圾收集回收机制清除这些对象,当这些对象所占空间超过
  • 共享单车的故事讲到哪了?

    来源丨海克财经与共享充电宝相差不多,共享单车已很久没有被国内热点新闻关照到了。除了一再涨价和用户直呼用不起了。近日多家媒体再发报道称,成都、天津、郑州等地多个共享单
  • 当家的盒马,加速谋生

    来源 | 价值星球Planet作者 | 归去来自己&ldquo;当家&rdquo;的盒马,开始加速谋生了。据盒马官微消息,盒马计划今年开放生鲜供应链,将其生鲜商品送往食堂。目前,盒马在上海已经与
  • 3699元!iQOO Neo8 Pro顶配版今日首销:1TB UFS 4.0同价位唯一

    5月23日,iQOO推出了全新的iQOO Neo8系列,包含iQOO Neo8和iQOO Neo8 Pro两个版本,其中标准版搭载高通骁龙8+,而Pro版更是首发搭载了联发科天玑9200+旗舰
  • 首发天玑9200+ iQOO Neo8系列发布首销售价2299元起

    2023年5月23日晚,iQOO Neo8系列正式发布。其中,Neo系列首款Pro之作——iQOO Neo8 Pro强悍登场,限时售价3099元起;价位段最强性能手机iQOO Neo8同期上市
  • 英特尔Xe HPG游戏显卡:拥有512EU,单风扇版本

    据10 月 30 日外媒 TheVerge 消息报道,英特尔 Xe HPG Arc Alchemist 的正面实被曝光,不仅拥有 512 EU 版显卡,还拥有 128EU 的单风扇版本。另外,这款显卡 PCB
Top