文章詳情頁
Spring數據庫多數據源路由配置過程圖解
瀏覽:19日期:2023-08-30 16:56:37
項目中需要根據不同業務進行分庫,首先是將業務不同業務映射到不同過的數據庫( biz --> db,可能存在多對一情況),
查看springjdbc源碼發現AbstractRoutingDataSource類作為一個數據源路由抽象類,可以擔當這個事情,其設計思想也比較簡單,
首先將多個數據源的映射關系自己維護完成后注入進來,然后自己定義一個路由規則,重點部分見代碼:
首先可以看到該類是一個抽象類,重點關注變量targetDataSource和resolvedDataSources.
其中targetDataSource用于將用戶建立的映射關系注入進來,可以通過如下方法
resolvedDataSources用于真正存儲依賴關系,targetDataSource僅僅是個中介,解析代碼見下圖
核心路由方法:
是不是很清楚,首先獲取數據源映射key,然后通過key獲取數據源
數據源映射獲取方法為抽象方法,見下圖:
實現時需要注意線程安全,最佳實現時通過ThreadLocal將在dbsql執行前將key設置進去,以便后來獲取這個key,
調用入口:
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。
標簽:
Spring
相關文章:
排行榜