文章詳情頁
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ī)則,重點部分見代碼:
首先可以看到該類是一個抽象類,重點關注變量targetDataSource和resolvedDataSources.
其中targetDataSource用于將用戶建立的映射關系注入進來,可以通過如下方法
resolvedDataSources用于真正存儲依賴關系,targetDataSource僅僅是個中介,解析代碼見下圖
核心路由方法:
是不是很清楚,首先獲取數(shù)據(jù)源映射key,然后通過key獲取數(shù)據(jù)源
數(shù)據(jù)源映射獲取方法為抽象方法,見下圖:
實現(xiàn)時需要注意線程安全,最佳實現(xiàn)時通過ThreadLocal將在dbsql執(zhí)行前將key設置進去,以便后來獲取這個key,
調用入口:
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。
標簽:
Spring
相關文章:
排行榜