GoLang分布式鎖與snowflake雪花算法
go語言在網(wǎng)絡(luò)服務(wù)模塊有著得天獨厚的優(yōu)勢;傳送門詳細介紹了涉及到的分布式相關(guān)技術(shù)。
分布式id生成器
Snowflake(雪花算法),由Twitter提出并開源,可在分布式環(huán)境下用于生成唯一ID的算法。

生成的Id是64位(int64)數(shù)值類型,包含4部分:
- 41bit的時間戳(毫秒):一般是相對系統(tǒng)上線時間的毫秒數(shù)(可用69年);
- 5bit的數(shù)據(jù)中心id+5bit的機器id:表示工作的計算機;實際使用時可根據(jù)情況調(diào)整兩者間的比例;
- 12bit序列號:區(qū)分同一個計算機在相同毫秒時間內(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來模擬;
負載均衡
從n個服務(wù)節(jié)點中,挑選一個的思路了:
- 按順序挑
- 隨機挑一個
- 根據(jù)某種權(quán)重,對節(jié)點進行排序,選擇權(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-09
Golang使用crypto/ed25519實現(xiàn)數(shù)字簽名和驗證
本文將深入探討如何在?Golang?中使用?crypto/ed25519?進行數(shù)字簽名和驗證,我們將從基本原理開始,逐步引導(dǎo)讀者了解生成密鑰對、進行數(shù)字簽名,以及驗證簽名的具體過程,希望對大家有所幫助2024-02-02
golang之數(shù)據(jù)驗證validator的實現(xiàn)
這篇文章主要介紹了golang之數(shù)據(jù)驗證validator的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10

