GoLang分布式鎖與snowflake雪花算法
go語言在網(wǎng)絡(luò)服務(wù)模塊有著得天獨厚的優(yōu)勢;傳送門詳細(xì)介紹了涉及到的分布式相關(guān)技術(shù)。
分布式id生成器
Snowflake(雪花算法),由Twitter提出并開源,可在分布式環(huán)境下用于生成唯一ID的算法。
生成的Id是64位(int64)數(shù)值類型,包含4部分:
- 41bit的時間戳(毫秒):一般是相對系統(tǒng)上線時間的毫秒數(shù)(可用69年);
- 5bit的數(shù)據(jù)中心id+5bit的機(jī)器id:表示工作的計算機(jī);實際使用時可根據(jù)情況調(diào)整兩者間的比例;
- 12bit序列號:區(qū)分同一個計算機(jī)在相同毫秒時間內(nèi)的生產(chǎn)的ID(支持1毫秒4096條);
github.com/bwmarrin/snowflake
提供了一個輕量級的實現(xiàn):
package main import ( "fmt" "github.com/bwmarrin/snowflake" "time" ) func main() { n, err := snowflake.NewNode(time.Now().UnixMilli() % 1024) if err != nil { fmt.println(err) os.Exit(1) } for i := 0; i < 10; i++ { id := n.Generate() fmt.Println("id", id.Int64()) fmt.Println( "node: ", id.Node(), "step: ", id.Step(), "time: ", id.Time(), ) } }
分布式鎖
可通過redis的setnx
來模擬分布式鎖:
- 設(shè)定成功時,為上鎖;
- 釋放鎖時,刪除對應(yīng)的鍵;
import ( "fmt" "sync" "time" "github.com/go-redis/redis" ) func incr() { client := redis.NewClient(&redis.Options{ Addr: "localhost:6379", Password: "", // no password set DB: 0, // use default DB }) var lockKey = "counter_lock" var counterKey = "counter" // lock resp := client.SetNX(lockKey, 1, time.Second*5) lockSuccess, err := resp.Result() if err != nil || !lockSuccess { fmt.Println(err, "lock result: ", lockSuccess) return } // counter ++ getResp := client.Get(counterKey) cntValue, err := getResp.Int64() if err == nil { cntValue++ resp := client.Set(counterKey, cntValue, 0) _, err := resp.Result() if err != nil { // log err println("set value error!") } } println("current counter is ", cntValue) // unlock delResp := client.Del(lockKey) unlockSuccess, err := delResp.Result() if err == nil && unlockSuccess > 0 { println("unlock success!") } else { println("unlock failed", err) } }
也可通過zookeeper或etcd來模擬;
負(fù)載均衡
從n個服務(wù)節(jié)點中,挑選一個的思路了:
- 按順序挑
- 隨機(jī)挑一個
- 根據(jù)某種權(quán)重,對節(jié)點進(jìn)行排序,選擇權(quán)重最大/小的那一個
到此這篇關(guān)于GoLang分布式鎖與snowflake雪花算法的文章就介紹到這了,更多相關(guān)GoLang分布式鎖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Golang中urlencode與urldecode編碼解碼詳解
這篇文章主要給大家介紹了關(guān)于Golang中urlencode與urldecode編碼解碼的相關(guān)資料,在Go語言中轉(zhuǎn)碼操作非常方便,可以使用內(nèi)置的encoding包來快速完成轉(zhuǎn)碼操作,Go語言中的encoding包提供了許多常用的編碼解碼方式,需要的朋友可以參考下2023-09-09Golang使用crypto/ed25519實現(xiàn)數(shù)字簽名和驗證
本文將深入探討如何在?Golang?中使用?crypto/ed25519?進(jìn)行數(shù)字簽名和驗證,我們將從基本原理開始,逐步引導(dǎo)讀者了解生成密鑰對、進(jìn)行數(shù)字簽名,以及驗證簽名的具體過程,希望對大家有所幫助2024-02-02golang之?dāng)?shù)據(jù)驗證validator的實現(xiàn)
這篇文章主要介紹了golang之?dāng)?shù)據(jù)驗證validator的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10