1. 程式人生 > 程式設計 >springboot多租戶設計過程圖解

springboot多租戶設計過程圖解

這篇文章主要介紹了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. 附贈一張租戶表

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。