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

一個注解搞定多數據源切換,你學會了嗎?

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

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

數據源

數據源的意思是“數據庫應用程序所使用的數據庫或者數據庫服務器”;數據源也即數據的來源,是提供某種所需要數據的器件或原始媒體,在數據源中存儲了所有建立數據庫連接的信息,通過提供正確的數據源名稱,可以找到相應的數據庫連接。

@DS

我們先來看看這個注解的使用

<!--配置多數據源-->
        <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
        # 配置獲取連接等待超時的時間
        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 的數據源,那么你在使用的時候,可以這樣,在我們的方法,或者類上面

@DS("slave_1")

這個注解,你可以使用在你的方法上面,你也可以使用在你的類上面,(一般是用在mapper、service),使用過該注解的方法即可操作到對應的數據源。既然我們知道怎么去使用這個注解了,那么就得來看看這個源碼的部分了。

圖片圖片

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

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

圖片圖片

當我們發送具體的操作請求的時候,進行數據操作時,方法會被com.baomidou.dynamic.datasource.aop.DynamicDataSourceAnnotationInterceptor攔截

圖片圖片

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

進行數據操作時,會調用org.springframework.jdbc.datasource.getConnection()方法;

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

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

但是還有一個問題了,那就是不可在事務中切換數據庫,保證事務需要方法使用同一連接,使用@DS(dataSourceOne)方法調用@DS(dataSourceTwo)無法切換連接,會導致方法報錯。

責任編輯:武曉燕 來源: Java極客技術
相關推薦

2024-01-18 09:38:00

Java注解JDK5

2021-10-04 09:29:41

對象池線程池

2023-03-26 22:02:53

APMPR監控

2024-06-21 08:15:25

2024-06-19 09:47:21

2022-12-22 08:14:54

2023-09-19 08:03:50

rebase?merge

2023-04-27 08:42:50

效果

2022-02-08 09:09:45

智能指針C++

2024-04-01 08:13:59

排行榜MySQL持久化

2022-01-20 07:31:49

架構

2024-01-19 08:25:38

死鎖Java通信

2024-02-04 00:00:00

Effect數據組件

2023-07-26 13:11:21

ChatGPT平臺工具

2023-01-10 08:43:15

定義DDD架構

2023-08-01 12:51:18

WebGPT機器學習模型

2024-01-02 12:05:26

Java并發編程

2024-01-11 08:21:33

Jetpack數據技術

2024-09-26 09:10:08

2023-07-10 07:17:29

無效化空窗口
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: av一级 | 亚洲 中文 欧美 日韩 在线观看 | 国产在线精品一区二区 | 成人精品| 欧美mv日韩mv国产网站91进入 | av网站在线免费观看 | 天天色影视综合 | 欧美日韩精品一区二区 | 成人精品鲁一区一区二区 | 91av在线免费看 | av日韩高清 | 日本一区二区三区在线观看 | 黄色精品 | 伦理二区 | 久久99精品国产麻豆婷婷 | 亚洲国产二区 | 日韩国产在线 | 久草久草久草 | 国产精品成人一区 | 亚洲高清在线 | 激情毛片 | 成人在线视频免费观看 | 日本一区不卡 | 狠狠亚洲| 男女羞羞视频免费看 | 成人国产免费观看 | 91在线看 | 国产综合一区二区 | 日日干天天操 | 毛片大全| 国产在线精品免费 | 神马久久av | 永久免费在线观看 | 欧美中文字幕一区二区三区亚洲 | zzzwww在线看片免费 | 国产乱码精品一区二三赶尸艳谈 | 精品日韩一区二区三区av动图 | 国产精品一区二区三区四区 | 国产人成在线观看 | 亚洲一区二区三区久久久 | 欧美videosex性极品hd |