成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

Spring數(shù)據(jù)庫多數(shù)據(jù)源路由配置過程圖解

瀏覽:34日期:2023-08-30 16:56:37

項目中需要根據(jù)不同業(yè)務進行分庫,首先是將業(yè)務不同業(yè)務映射到不同過的數(shù)據(jù)庫( biz --> db,可能存在多對一情況),

查看springjdbc源碼發(fā)現(xiàn)AbstractRoutingDataSource類作為一個數(shù)據(jù)源路由抽象類,可以擔當這個事情,其設計思想也比較簡單,

首先將多個數(shù)據(jù)源的映射關系自己維護完成后注入進來,然后自己定義一個路由規(guī)則,重點部分見代碼:

Spring數(shù)據(jù)庫多數(shù)據(jù)源路由配置過程圖解

首先可以看到該類是一個抽象類,重點關注變量targetDataSource和resolvedDataSources.

其中targetDataSource用于將用戶建立的映射關系注入進來,可以通過如下方法

Spring數(shù)據(jù)庫多數(shù)據(jù)源路由配置過程圖解

resolvedDataSources用于真正存儲依賴關系,targetDataSource僅僅是個中介,解析代碼見下圖

Spring數(shù)據(jù)庫多數(shù)據(jù)源路由配置過程圖解

核心路由方法:

Spring數(shù)據(jù)庫多數(shù)據(jù)源路由配置過程圖解

是不是很清楚,首先獲取數(shù)據(jù)源映射key,然后通過key獲取數(shù)據(jù)源

數(shù)據(jù)源映射獲取方法為抽象方法,見下圖:

Spring數(shù)據(jù)庫多數(shù)據(jù)源路由配置過程圖解

實現(xiàn)時需要注意線程安全,最佳實現(xiàn)時通過ThreadLocal將在dbsql執(zhí)行前將key設置進去,以便后來獲取這個key,

調用入口:

Spring數(shù)據(jù)庫多數(shù)據(jù)源路由配置過程圖解

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章: