欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go 簡單實現(xiàn)多租戶數(shù)據(jù)庫隔離

 更新時間:2023年05月14日 08:48:51   作者:小雄Ya  
本文主要介紹了Go 簡單實現(xiàn)多租戶數(shù)據(jù)庫隔離,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

多租戶

在 SaaS 系統(tǒng)中多租戶是一個很重要的架構(gòu),在服務上僅需運行一個軟件實例就能夠支持每個租戶的功能,它們之間的數(shù)據(jù)互相隔離。就比如 Gitee ,每個用戶或組織都擁有自己的空間。它們自己的數(shù)據(jù)僅在自己的空間內(nèi)流通,彼此之間互不影響。多租戶其實就是一種軟件設計結(jié)構(gòu)。
所以。租戶模型其實就是分離數(shù)據(jù)的方式:

  • 單租戶:一個應用一個數(shù)據(jù)庫。其實就是應用分離,數(shù)據(jù)分離。
  • 多租戶:一個應用多個數(shù)據(jù)庫。就是同一個應用不同數(shù)據(jù)庫。

為什么需要多租戶?

剛畢業(yè)第一家公司,接觸的第一個項目的內(nèi)容主要幫助客戶提高生產(chǎn)力。每次有一個很大的問題就是,合作一個客戶,項目復制一份出來,然后改成該客戶定制的功能需求。這樣就導致相同功能要更新多份代碼,還要注意可能會出現(xiàn)因不同客戶的不同需求問題。整個過程就導致了一個很大的維護成本的支出。

多租戶應用程序的維護更容易,只需根據(jù)每個租戶專屬標志,然后提供不同的功能,且公共的功能可以集中更新升級。

數(shù)據(jù)隔離方式

在 SaaS 系統(tǒng)中一般分離租戶的數(shù)據(jù)有兩種模型:

  • 數(shù)據(jù)的邏輯分離:所有租戶只使用一個數(shù)據(jù)庫。它們的數(shù)據(jù)通過為每個租戶使用一個唯一標識符來分隔。
  • 數(shù)據(jù)的物理分離:一個租戶分配一個數(shù)據(jù)庫。就是一個應用對應多個數(shù)據(jù)庫。每個數(shù)據(jù)庫就是一個租戶。這種方式在客戶的增長時擴展了應用的功能,也方便擴展數(shù)據(jù)庫

物理分離詳細實現(xiàn)

目標:每個請求過來,應用程序能夠識別租戶,并從該租戶數(shù)據(jù)庫中進行提供數(shù)據(jù)。

  • 公共數(shù)據(jù)庫:存儲所有租戶相關(guān)全局配置和所有租戶數(shù)據(jù)庫信息。
  • 租戶數(shù)據(jù)庫:每個租戶獨立的的數(shù)據(jù)庫,根據(jù)租戶需要保存數(shù)據(jù)。

啟動服務

創(chuàng)建 main 文件,并使用 Gin 框架。初始化一個簡單的應用程序并創(chuàng)建基本的路由。

func main() {
    r := gin.Default()
    r.GET("/ping", func(c *gin.Context) {
        c.JSON(http.StatusOK, gin.H{
            "message": "pong",
        })
    })
    r.Run()
}

數(shù)據(jù)庫配置

在公共數(shù)據(jù)庫創(chuàng)建一個保存租戶數(shù)據(jù)庫信息表并添加上租戶的數(shù)據(jù)庫。

Create Table db_tenant (
    id int primary key,
    db_name varchar(100) unique not null,
    db_domain  varchar(100) unique not null,
    conn_str varchar(200) not null,
    remark varchar(1000) ,
)

在配置文件中加入一個公共數(shù)據(jù)庫的連接配置,這樣就可以在服務啟動時第一次連接的是公共數(shù)據(jù)庫。接著需要實現(xiàn)根據(jù)請求連接到正確的租戶數(shù)據(jù)庫。主要使用 gorm 的 DBResolver ,多個數(shù)據(jù)庫的連接支持

func allDbConnect(db *db.gorm) (allDbs map[string]) {
?? ? db.Model(&db_tenant).Find(&allDbs)
? ? var gconn []gorm.Dialector
?? ? ?for _,connStr := range allDbs {
? ? ? ?db :=mysql.Open(connStr)
?? ??? ??? ??? ?gconn = append(gconn,db)
? ? }
db.Use(dbresolver.Register(dbresolver.Config{
? Sources: ?gconn,
? // sources/replicas 負載均衡策略
? Policy: dbresolver.RandomPolicy{},
})
? ?return allDbs
}

通過使用中間件來解析每個請求連接,從而確定整個請求是由哪個租戶數(shù)據(jù)庫來提供數(shù)據(jù)讀寫。中間件中主要的處理方式是得到租戶對應的數(shù)據(jù)庫連接名,然后從連接池中拿到該連接并設置在全局變量中。在業(yè)務邏輯處理中從全局拿到數(shù)據(jù)庫連接,就可以進行數(shù)據(jù)庫讀寫。

sr.Use(middlerware.dbResolve)
func dbResolve(ctx *gin.Context) {
?? ?dbName := ctx.Query("dbName")
?? ?setGlobalDb(dbName)
}
func dbOperater(){
?? ?db := getDb()
? var users []User
? db.Clauses(dbresolver.Use(dbName)).First(&users)
}

這樣就可以啟動項目,然后訪問 localhost:8003?dbName=db1 ,這樣就可以正常進行數(shù)據(jù)讀寫。

其實可以從域名上解析對應的數(shù)據(jù)庫連接。這里最重要就是對數(shù)據(jù)庫的解析。這里的例子只是實驗使用,其中還有很多可優(yōu)化的點。比如可以考慮使用連接池,這樣就不用在項目啟動時都全部創(chuàng)建數(shù)據(jù)庫連接,造成浪費。

到此這篇關(guān)于Go 簡單實現(xiàn)多租戶數(shù)據(jù)庫隔離的文章就介紹到這了,更多相關(guān)Go  多租戶隔離內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 如何使用proto組件編譯pb.go文件

    如何使用proto組件編譯pb.go文件

    這篇文章主要介紹了如何使用proto組件編譯pb.go文件的詳細過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • golang多次讀取http request body的問題分析

    golang多次讀取http request body的問題分析

    這篇文章主要給大家分析了golang多次讀取http request body的問題,文中通過代碼示例和圖文介紹的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下
    2024-01-01
  • Go語言實現(xiàn)操作MySQL的基礎知識總結(jié)

    Go語言實現(xiàn)操作MySQL的基礎知識總結(jié)

    這篇文章主要總結(jié)一下怎么使用Go語言操作MySql數(shù)據(jù)庫,文中的示例代碼講解詳細,需要的朋友可以參考以下內(nèi)容,希望對大家有所幫助
    2022-09-09
  • 手把手帶你走進Go語言之類型轉(zhuǎn)換

    手把手帶你走進Go語言之類型轉(zhuǎn)換

    每個函數(shù)都可以強制將一個表達式轉(zhuǎn)換成某種特定數(shù)據(jù)類型,本文給大家介紹了在Go語言中類型轉(zhuǎn)換的具體用法,講述的非常詳細,對大家的學習或工作具有一定的參考借鑒價值
    2021-09-09
  • 詳解Golang如何優(yōu)雅接入多個遠程配置中心

    詳解Golang如何優(yōu)雅接入多個遠程配置中心

    這篇文章主要為大家為大家介紹了Golang如何優(yōu)雅接入多個遠程配置中心詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • Go語言操作MySQL的知識總結(jié)

    Go語言操作MySQL的知識總結(jié)

    Go語言中的database/sql包提供了保證SQL或類SQL數(shù)據(jù)庫的泛用接口,并不提供具體的數(shù)據(jù)庫驅(qū)動。本文介紹了Go語言操作MySQL的相關(guān)知識,感興趣的可以了解一下
    2022-11-11
  • Go語言中常用語法編寫與優(yōu)化技巧小結(jié)

    Go語言中常用語法編寫與優(yōu)化技巧小結(jié)

    為了充分利用?Go?的潛力,我們需要了解如何優(yōu)化?Go?程序,本文將介紹一些常見的?Go?語言優(yōu)化技巧,并通過實際例子進行說明,希望對大家有所幫助
    2024-02-02
  • Go語言實現(xiàn)RSA加解密算法詳解

    Go語言實現(xiàn)RSA加解密算法詳解

    隨著互聯(lián)網(wǎng)的高速發(fā)展,人們對安全的要求也越來越高,加解密也變得越來越重要,本文主要為大家介紹了Go語言中實現(xiàn)RSA加解密與簽名驗證算法,希望對大家有所幫助
    2023-06-06
  • 深入了解Golang中的反射機制

    深入了解Golang中的反射機制

    反射是指在程序運行時動態(tài)地檢查和修改對象的能力,在Go語言中,通過反射可以在運行時檢查變量的類型、獲取結(jié)構(gòu)體字段和方法的信息,以及動態(tài)調(diào)用方法等操作,本文將帶你深入了解Golang中的反射機制,感興趣的同學可以跟著小編一起來學習
    2023-05-05
  • Go語言eclipse環(huán)境搭建圖文教程

    Go語言eclipse環(huán)境搭建圖文教程

    這篇文章主要介紹了Go語言eclipse環(huán)境搭建的方法,結(jié)合圖文形式詳細分析了在eclipse環(huán)境下開發(fā)Go語言所涉及的組件下載、安裝及相關(guān)設置方法,需要的朋友可以參考下
    2016-07-07

最新評論