GoLang分布式鎖與snowflake雪花算法
go語言在網(wǎng)絡(luò)服務(wù)模塊有著得天獨(dú)厚的優(yōu)勢(shì);傳送門詳細(xì)介紹了涉及到的分布式相關(guān)技術(shù)。
分布式id生成器
Snowflake(雪花算法),由Twitter提出并開源,可在分布式環(huán)境下用于生成唯一ID的算法。
生成的Id是64位(int64)數(shù)值類型,包含4部分:
- 41bit的時(shí)間戳(毫秒):一般是相對(duì)系統(tǒng)上線時(shí)間的毫秒數(shù)(可用69年);
- 5bit的數(shù)據(jù)中心id+5bit的機(jī)器id:表示工作的計(jì)算機(jī);實(shí)際使用時(shí)可根據(jù)情況調(diào)整兩者間的比例;
- 12bit序列號(hào):區(qū)分同一個(gè)計(jì)算機(jī)在相同毫秒時(shí)間內(nèi)的生產(chǎn)的ID(支持1毫秒4096條);
github.com/bwmarrin/snowflake
提供了一個(gè)輕量級(jí)的實(shí)現(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è)定成功時(shí),為上鎖;
- 釋放鎖時(shí),刪除對(duì)應(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個(gè)服務(wù)節(jié)點(diǎn)中,挑選一個(gè)的思路了:
- 按順序挑
- 隨機(jī)挑一個(gè)
- 根據(jù)某種權(quán)重,對(duì)節(jié)點(diǎn)進(jìn)行排序,選擇權(quán)重最大/小的那一個(gè)
到此這篇關(guān)于GoLang分布式鎖與snowflake雪花算法的文章就介紹到這了,更多相關(guān)GoLang分布式鎖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Golang實(shí)現(xiàn)將視頻按照時(shí)間維度剪切的工具
這篇文章主要為大家詳細(xì)介紹了如何利用Golang實(shí)現(xiàn)將視頻按照時(shí)間維度進(jìn)行剪切,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下2022-12-12Golang中urlencode與urldecode編碼解碼詳解
這篇文章主要給大家介紹了關(guān)于Golang中urlencode與urldecode編碼解碼的相關(guān)資料,在Go語言中轉(zhuǎn)碼操作非常方便,可以使用內(nèi)置的encoding包來快速完成轉(zhuǎn)碼操作,Go語言中的encoding包提供了許多常用的編碼解碼方式,需要的朋友可以參考下2023-09-09使用golang編寫一個(gè)并發(fā)工作隊(duì)列
這篇文章主要介紹了使用golang編寫一個(gè)并發(fā)工作隊(duì)列的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-05-05Golang使用crypto/ed25519實(shí)現(xiàn)數(shù)字簽名和驗(yàn)證
本文將深入探討如何在?Golang?中使用?crypto/ed25519?進(jìn)行數(shù)字簽名和驗(yàn)證,我們將從基本原理開始,逐步引導(dǎo)讀者了解生成密鑰對(duì)、進(jìn)行數(shù)字簽名,以及驗(yàn)證簽名的具體過程,希望對(duì)大家有所幫助2024-02-02golang之?dāng)?shù)據(jù)驗(yàn)證validator的實(shí)現(xiàn)
這篇文章主要介紹了golang之?dāng)?shù)據(jù)驗(yàn)證validator的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10go語言使用jwt認(rèn)證的實(shí)現(xiàn)
本文主要介紹了go語言使用jwt認(rèn)證的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04