您好,登錄后才能下訂單哦!
這篇文章主要介紹了springboot多租戶設計過程圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
1. 概述
根據不同用戶的請求,選擇不同的數據源,不同的數據源可以是Oracle、MySQL或者其它。用到的技術棧,沒有什么復雜的技術,可以看到,依賴也就加了幾個而已,如下:
2. 先睹為快
如下圖,header中tenant為zhangsan,則使用db_oauth為數據源,tenant為lisi,則使用db_test為數據源,tenant為wangwu,則使用db_jxc為數據源。不同的數據源可以是不同的數據庫類型,這里為了演示統一使用了MySQL,用不同的庫作為不同的數據源。
3. 實現原理3.1 先看一下入口這個controller,一個很正常的controller.
3.2 跟進service層,看一下這個bookService,一個正常的不能再正常的service.
3.3 跟進dao層,看一下這個bookDao
一個正常…似乎有些不正常的dao,主要是這里的這個jdbcTemplate,不是像以前一樣直接通過@Resource注入進來的,而是通過父類的getJdbcTemplate方法獲取的,下一步進到這個方法里邊看個究竟。
3.4 動態獲取jdbcTemplate
這里注入了一個datasourceProvider,首先從request的header中獲取租戶的標志,然后通過datasourceProvider的selectDataSource方法獲取數據源。
3.5 繼續跟進
這里通過一個map存儲著所有的數據源,如果沒有初始化,就將所有的數據源初始化完畢,然后放到這個map中,在使用的時候,通過租戶標志從map中獲取。也可以改成懶加載的模式,即下邊注釋的代碼,在需要的時候才進行數據源的初始化,然后放到map中,供以后使用。
3.6 Keep Going~
進去看一下這個map里邊put的是什么東西。首先從租戶數據源配置表中獲取所有的配置,然后對這些數據源進行一個個的初始化。getDataSouce方法中,也對數據源進行了一個map的映射,先放到一個容器中,如果初始化過了,直接拿出來使用即可。
3.7 這里才是真正的數據源初始化的地方,這里使用了druid,傳統的生成方式而已,沒有什么特別的地方。
3.8 需要注意的是,在系統啟動的時候,需要指定一個默認的數據源,這個數據源中存放著租戶的配置信息。
4. 附贈一張租戶表
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。