SAAS系統架構設計剖析

多租戶數據隔離

用戶擔心數據安全性,也就是要做數據隔離,不允許 A 租戶查到 B 租戶的數據

1、軟隔離

數據在一起,只不過帶著租戶 id 查詢

在底層驅動 jar 上進行封裝,強制帶上租戶 id
比如:MySQL、MQ、Redis,都是一個道理
MySQL 所有的數據操作,必須帶上租戶 id
MQ 發送消息的時候,必須帶上租戶 id
Redis 拼裝 key 的時候,必須帶上租戶 id
RPC 遠程調用的時候,把租戶 id 放到請求頭 header 中,
然后被調用模塊可以通過過濾器來從請求頭中獲取租戶 id,然后保存到 ThreadLocal 中

租戶 id 怎么自動拼裝
建議使用上下文 ThreadLocal
可以在用戶登錄之后,過濾器、攔截器解析 Token 把租戶 id 放到 ThreadLocal 中

多線程、線程池的時候,把 ThreadLocal 復制過去

2、硬隔離

直接按租戶分庫,但是這么做成本太高了

中小公司直接分庫都行,估計都沒有多少個租戶
可以考慮等租戶多了之后,再對系統進行重構升級

可以使用 MP 提供的 dynamic-datasource 動態數據源來實現

底層其實很簡單,其實就是使用 Map 來存儲 tenant 租戶 id 和 datasource 數據源的映射關系,
然后通過租戶 id 獲取到對應的數據源,然后獲取 connection 連接,來訪問租戶自己的數據

tenant 租戶 id 和 datasource 數據源的映射關系可以存儲在 MySQL 或者 Redis 數據庫中,
然后當新增租戶的時候,動態刷新 Map 來保證數據的一致性,否則 Map 中沒有新增租戶的數據源信息

總結:
小用戶一起軟隔離得了,

大用戶、vip 用戶,就硬隔離,分庫

租戶定制化

用戶要自己加字段,怎么辦?

1、核心業務數據使用 MySQL
2、動態拓展的使用 NoSQL DB,比如:Mongo DB

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/23454.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/23454.shtml
英文地址,請注明出處:http://en.pswp.cn/web/23454.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【論文精讀】DCRNN-擴散圖卷積循環神經網絡

DCRNN 模型是南加州大學的 Li 等人發表在 I C L R 2018 ICLR 2018 ICLR2018 會議上一個用于交通預測的時空預測模型,論文題目為: 《DIFFUSION CONVOLUTIONAL RECURRENT NEURAL NETWORK: DATA-DRIVEN TRAFFIC FORECASTING》,文章地址為: https://arxiv.org/abs/1707.01926。 …

vs中運行程序時,報不能運行解決方式

問題 在vs中編譯運行程序中,如果程序還在運行,編譯會報錯,但是在后臺又找不到對應的程序 解決方式 1、tasklist | find “進程名” 2、taskkill /PID

【實戰】kafka3.X kraft模式集群搭建

文章目錄 前言kafka2.0與3.x對比準備工作JDK安裝kafka安裝服務器增加hosts 修改Kraft協議配置文件格式化存儲目錄 啟動集群停止集群測試Kafka集群創建topic查看topic列表查看消息詳情生產消息消費消息查看消費者組查看消費者組列表 前言 相信很多同學都用過Kafka2.0吧&#xf…

二叉樹的鏡像--c++【做題記錄】

【問題描述】 給定擴展二叉樹的前序序列,構建二叉樹。 求這課二叉樹的鏡像,并輸出其前序遍歷序列。 【輸入形式】 輸入擴展二叉樹的前序序列。 【輸出形式】 輸出鏡像二叉樹的前序遍歷序列。 【樣例輸入】 ab##cd##e## 【樣例輸出】 鏡像后二叉樹的前序遍…

功能問題:如何防止接口重復請求?

大家好,我是大澈! 本文約 1400 字,整篇閱讀約需 3 分鐘。 防止接口重復請求在軟件開發中非常重要,重復請求必然會導致服務器資源的浪費。 因為每次請求都需要服務器進行處理,如果請求是重復的,那么服務…

乘船過河(ship)

合肥市第33屆信息學競賽(2016年) 題目描述 Description 卡卡西和小朋友們要乘船過河了,港口有很多條船可以租到,并且之間沒有區別,每條船的出租費用也是一樣的。但是一條船最多只能乘坐兩個人,且乘客的總…

STM32 IIC 使用 HAL 庫操作eeprom

在STM32上通過I2C接口(注意:在標準STM32庫中,I2C接口通常被寫為"I2C"而不是"IIC")與EEPROM芯片通信時,你需要遵循I2C通信協議,并使用STM32的HAL庫或標準外設庫(如果適用&am…

tomcat配置請求的最大參數個數和請求數據大小

maxParameterCount"10000" maxPostSize"10485760" maxParameterCount:單個請求最大請求參數個數; maxPostSize:單個請求最大數據大小,1048576010M;

基本算法——位運算

a^b 原題鏈接&#xff1a;登錄—專業IT筆試面試備考平臺_牛客網 題目描述 運行代碼 #include<iostream> using namespace std; long long a,b,c,t1; int main() {cin>>a>>b>>c;for(;b;b/2){if(b&1)tt*a%c;aa*a%c;}cout<<t%c; } 代碼思路…

汽車軟件 OTA技術解析

汽車軟件 OTA 技術概述 在當今汽車行業中,軟件定義汽車的概念逐漸深入人心。隨著汽車智能化和網聯化的發展,汽車軟件的重要性日益凸顯。而汽車軟件 OTA(Over-the-Air)技術作為一種重要的軟件升級和維護方式,正逐漸成為汽車行業的熱點話題。 汽車軟件 OTA 技術是指通過無線…

邏輯回歸及python實現

概述 logistic回歸是一種廣義線性回歸&#xff08;generalized linear model&#xff09;&#xff0c;因此與多重線性回歸分析有很多相同之處。它們的模型形式基本上相同&#xff0c;都具有 w‘xb&#xff0c;其中w和b是待求參數&#xff0c;其區別在于他們的因變量不同&#x…

App Inventor 2 復制屏幕功能,界面設計更便捷,避免誤刪組件

“復制屏幕”功能全新上線&#xff0c;中文網獨有&#xff08;MIT沒有此功能&#xff09;&#xff0c;可以復制屏幕中的普通組件、圖片、附件、拓展、代碼塊。更多升級詳情可查看發布日志。 下面演示一下屏幕的復制效果&#xff1a; 1、Screen1屏幕上有若干組件、及一個SQLit…

美業SaaS系統源碼分享-收銀管理的主要功能

美業SaaS系統 連鎖多門店美業收銀系統源碼 多門店管理 / 會員管理 / 預約管理 / 排班管理 / 商品管理 / 活動促銷 PC管理后臺、手機APP、iPad APP、微信小程序 ? 博弈美業-收銀管理功能 1、同時支持支付寶和微信支付&#xff0c;具有簡單便捷安全等優點&#xff0c;并且符…

MySQL之查詢性能優化(八)

查詢性能優化 MySQL查詢優化器的局限性 MySQL的萬能"嵌套循環"并不是對每種查詢都是最優的。不過還好&#xff0c;MySQL查詢優化器只對少部分查詢不適用&#xff0c;而且我們往往可以通過改寫查詢讓MySQL高效地完成工作。還有一個好消息&#xff0c;MySQL5.6版本正…

Java開發注意事項

注意&#xff1a;測試類中使用Autowired注解注入Bean&#xff0c;不要使用RequiredArgsConstructor注解注入Bean 正確示范: import org.springframework.boot.test.context.SpringBootTest; import org.springframework.beans.factory.annotation.Autowired;SpringBootTest c…

Ffmpeg安裝和簡單使用

Ffmpeg安裝 下載并解壓 進入官網 (https://ffmpeg.org/download.html)&#xff0c;選擇 Window 然后再打開的頁面中下滑找到 release builds&#xff0c;點擊 zip 文件下載 環境變量配置 下載好之后解壓&#xff0c;找到 bin 文件夾&#xff0c;里面有3個 .exe 文件 然后復制…

中國互聯網第一人的故事__許榕生的不平凡的經歷

中國互聯網第一人的故事&#xff3f;&#xff3f;許榕生的不平凡的經歷 目錄 零 高考之際談高考成功者 一 幸運的高考考生 二 抓住時機考研上岸 三 當年連接互聯網的經過 四 互聯網進入中國的緣由 五 互聯網一誕生就顯神威 六 互聯網強國之路&#xff0c;我們在路上 零…

優思學院|六西格瑪黑帶官方的報考條件是什么?

經常有人私信問我六西格瑪黑帶證書要如何取得&#xff0c;要學歷證明嗎&#xff1f;要帶項目嗎&#xff1f;要注冊嗎&#xff1f; 首先&#xff0c;直接一點說&#xff0c;和任何學科一樣&#xff0c;取得六西格瑪證書的方法主要是通過上課學習和考試。然而&#xff0c;關于六…

fastapi實例

quick start 安裝 pip install fastapi# ASGI服務器&#xff0c;生成環境可以使用uvicorn pip install uvicorn代碼 from fastapi import FastAPI import uvicorn# 創建一個app實例 app FastAPI()# 編寫一個路徑操作裝飾器 app.get("/") # 編寫一個路徑操作函數 …

【ARM Cache 及 MMU 系列文章 6.2 -- ARMv8/v9 Cache 內部數據讀取方法詳細介紹】

請閱讀【ARM Cache 及 MMU/MPU 系列文章專欄導讀】 及【嵌入式開發學習必備專欄】 文章目錄 Direct access to internal memoryL1 cache encodingsL1 Cache Data 寄存器Cache 數據讀取代碼實現Direct access to internal memory 在ARMv8架構中,緩存(Cache)是用來加速數據訪…