成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一個(gè)注解搞定多數(shù)據(jù)源切換,你學(xué)會(huì)了嗎?

開(kāi)發(fā) 前端
數(shù)據(jù)操作完成后,方法返回第二步中的攔截器,執(zhí)行DynamicDataSourceContextHolder.poll();清除掉此次Threadlocal中的數(shù)據(jù)源,避免影響后續(xù)數(shù)據(jù)操作。

我們都知道,再開(kāi)發(fā)的過(guò)程中,對(duì)于多個(gè)數(shù)據(jù)庫(kù),就會(huì)有各種各樣的數(shù)據(jù)源,比如Oracle,比如 Mysql,并且再開(kāi)發(fā)的過(guò)程中,我們很有可能會(huì)同時(shí)使用到兩個(gè)數(shù)據(jù)庫(kù),這樣就設(shè)計(jì)到了切換不同的數(shù)據(jù)源來(lái)進(jìn)行實(shí)現(xiàn),就比如我們?cè)?Oracle 的數(shù)據(jù)庫(kù)中去查詢一些必要的數(shù)據(jù),然后讓這些源頭數(shù)據(jù)進(jìn)入到 Mysql ,這個(gè)時(shí)候,如果不通過(guò)第三方的工具,比如 dataWorks或者其他的組件的話, 那么就得通過(guò) Java 代碼來(lái)進(jìn)行實(shí)現(xiàn)了,今天了不起就來(lái)給大家介紹一下這個(gè)關(guān)于這個(gè)一個(gè)注解就切換數(shù)據(jù)源的操作。

數(shù)據(jù)源

數(shù)據(jù)源的意思是“數(shù)據(jù)庫(kù)應(yīng)用程序所使用的數(shù)據(jù)庫(kù)或者數(shù)據(jù)庫(kù)服務(wù)器”;數(shù)據(jù)源也即數(shù)據(jù)的來(lái)源,是提供某種所需要數(shù)據(jù)的器件或原始媒體,在數(shù)據(jù)源中存儲(chǔ)了所有建立數(shù)據(jù)庫(kù)連接的信息,通過(guò)提供正確的數(shù)據(jù)源名稱,可以找到相應(yīng)的數(shù)據(jù)庫(kù)連接。

@DS

我們先來(lái)看看這個(gè)注解的使用

<!--配置多數(shù)據(jù)源-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
            <version>3.5.0</version>
        </dependency>

修改YML 的配置如下

datasource:
    dynamic:
      druid:
        initial-size: 5
        min-idle: 5
        maxActive: 20
        # 配置獲取連接等待超時(shí)的時(shí)間
        maxWait: 60000
        # 配置間隔多久才進(jìn)行一次檢測(cè),檢測(cè)需要關(guān)閉的空閑連接,單位是毫秒
        timeBetweenEvictionRunsMillis: 6000
        # 配置一個(gè)連接在池中最小生存的時(shí)間,單位是毫秒
        minEvictableIdleTimeMillis: 60000
        # 配置一個(gè)連接在池中最大生存的時(shí)間,單位是毫秒
        maxEvictableIdleTimeMillis: 900000
        validationQuery: SELECT 1 FROM DUAL
        testWhileIdle: true
        testOnBorrow: false
        testOnReturn: false
        # 打開(kāi)PSCache,并且指定每個(gè)連接上PSCache的大小
        poolPreparedStatements: true
        maxPoolPreparedStatementPerConnectionSize: 20
      primary: master #設(shè)置默認(rèn)的數(shù)據(jù)源或者數(shù)據(jù)源組,默認(rèn)值即為master
      strict: false #嚴(yán)格匹配數(shù)據(jù)源,默認(rèn)false. true未匹配到指定數(shù)據(jù)源時(shí)拋異常,false使用默認(rèn)數(shù)據(jù)源
      datasource:
        master:
          driver-class-name: com.mysql.cj.jdbc.Driver # 3.2.0開(kāi)始支持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開(kāi)始支持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

注意這個(gè) dynamic 一定是我們引入的 mybatis 當(dāng)中的,這個(gè)時(shí)候,如果我們?nèi)ナ褂眠@個(gè)@DS注解的話,那么就可以去切換數(shù)據(jù)源,比如我們?cè)谂渲梦募校渲昧?master  還有一個(gè) slave_1 的數(shù)據(jù)源,那么你在使用的時(shí)候,可以這樣,在我們的方法,或者類上面

@DS("slave_1")

這個(gè)注解,你可以使用在你的方法上面,你也可以使用在你的類上面,(一般是用在mapper、service),使用過(guò)該注解的方法即可操作到對(duì)應(yīng)的數(shù)據(jù)源。既然我們知道怎么去使用這個(gè)注解了,那么就得來(lái)看看這個(gè)源碼的部分了。

圖片圖片

首先mybatis-plus使用com.baomidou.dynamic.datasource.AbstractRoutingDataSource繼承 AbstractDataSource接管數(shù)據(jù)源;

具體實(shí)現(xiàn)類(ctrl+alt+b可以查看抽象類或者的具體實(shí)現(xiàn)類)為com.baomidou.dynamic.datasource.DynamicRoutingDataSource。項(xiàng)目初始化調(diào)用public synchronized void addDataSource(String ds, DataSource dataSource)加載數(shù)據(jù)源,數(shù)據(jù)源存進(jìn)dataSourceMap中。

圖片圖片

當(dāng)我們發(fā)送具體的操作請(qǐng)求的時(shí)候,進(jìn)行數(shù)據(jù)操作時(shí),方法會(huì)被com.baomidou.dynamic.datasource.aop.DynamicDataSourceAnnotationInterceptor攔截

圖片圖片

攔截器首先從被攔截的方法或者類(一般@DS注解用于Service,也可用于Mapper和Controller)上尋找@DS注解,獲取到@DS注解的值后將其存入com.baomidou.dynamic.datasource.toolkit.DynamicDataSourceContextHolder;DynamicDataSourceContextHolder使用ThreadLocal存儲(chǔ)當(dāng)前線程的數(shù)據(jù)源名。

進(jìn)行數(shù)據(jù)操作時(shí),會(huì)調(diào)用org.springframework.jdbc.datasource.getConnection()方法;

getConnection()方法最終調(diào)用了com.baomidou.dynamic.datasource.AbstractRoutingDataSource的getConnection()方法;

數(shù)據(jù)操作完成后,方法返回第二步中的攔截器,執(zhí)行DynamicDataSourceContextHolder.poll();清除掉此次Threadlocal中的數(shù)據(jù)源,避免影響后續(xù)數(shù)據(jù)操作。

但是還有一個(gè)問(wèn)題了,那就是不可在事務(wù)中切換數(shù)據(jù)庫(kù),保證事務(wù)需要方法使用同一連接,使用@DS(dataSourceOne)方法調(diào)用@DS(dataSourceTwo)無(wú)法切換連接,會(huì)導(dǎo)致方法報(bào)錯(cuò)。

責(zé)任編輯:武曉燕 來(lái)源: Java極客技術(shù)
相關(guān)推薦

2024-01-18 09:38:00

Java注解JDK5

2021-10-04 09:29:41

對(duì)象池線程池

2023-09-19 08:03:50

rebase?merge

2023-03-26 22:02:53

APMPR監(jiān)控

2024-06-21 08:15:25

2024-06-19 09:47:21

2022-12-22 08:14:54

2022-01-20 07:31:49

架構(gòu)

2022-02-08 09:09:45

智能指針C++

2023-04-27 08:42:50

效果

2024-04-01 08:13:59

排行榜MySQL持久化

2024-01-19 08:25:38

死鎖Java通信

2023-01-10 08:43:15

定義DDD架構(gòu)

2024-02-04 00:00:00

Effect數(shù)據(jù)組件

2023-07-26 13:11:21

ChatGPT平臺(tái)工具

2024-01-11 08:21:33

Jetpack數(shù)據(jù)技術(shù)

2023-04-04 09:13:15

2023-10-10 11:04:11

Rust難點(diǎn)內(nèi)存

2024-05-06 00:00:00

InnoDBView隔離

2024-07-31 08:39:45

Git命令暫存區(qū)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 欧美一区二区三区在线免费观看 | 国产精品成av人在线视午夜片 | 国产精品不卡一区 | 国产欧美日韩在线 | 波多野结衣中文视频 | 黄色片亚洲| 精品一区国产 | 久久久久亚洲国产| 国产一级在线观看 | 中文字幕在线不卡播放 | 免费观看黄色片视频 | 久久久久久久综合色一本 | 亚洲高清网| 精品国产久 | 午夜网站视频 | 在线国产一区二区 | 成人免费观看男女羞羞视频 | 一区二区高清不卡 | 91精品国产综合久久婷婷香蕉 | 亚洲 欧美 另类 综合 偷拍 | 日韩一区二区在线视频 | 日韩精品久久一区 | 成人精品福利 | 天天操天天干天天曰 | 自拍偷拍精品 | 国产免费一级一级 | 一区二区三区高清 | 国产高清av免费观看 | 丝袜毛片 | 免费黄色大片 | 精品欧美激情精品一区 | 成人精品久久日伦片大全免费 | 亚洲精品久久久久久国产精华液 | 亚洲精品片| 国产激情精品视频 | 在线永久看片免费的视频 | 在线欧美小视频 | 欧美在线a| 91麻豆精品国产91久久久更新资源速度超快 | 黄色一级大片在线免费看产 | 国产成人精品免费 |