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

GoLang分布式鎖與snowflake雪花算法

 更新時(shí)間:2022年12月22日 16:07:28   作者:alwaysrun  
這篇文章主要介紹了GoLang分布式鎖與snowflake雪花算法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

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í)間維度剪切的工具

    Golang實(shí)現(xiàn)將視頻按照時(shí)間維度剪切的工具

    這篇文章主要為大家詳細(xì)介紹了如何利用Golang實(shí)現(xiàn)將視頻按照時(shí)間維度進(jìn)行剪切,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下
    2022-12-12
  • Golang性能優(yōu)化的技巧分享

    Golang性能優(yōu)化的技巧分享

    性能優(yōu)化的前提是滿足正確可靠、簡(jiǎn)潔清晰等質(zhì)量因素,針對(duì)?Go語言特性,本文為大家整理了一些Go語言相關(guān)的性能優(yōu)化建議,感興趣的可以了解一下
    2023-07-07
  • Golang中urlencode與urldecode編碼解碼詳解

    Golang中urlencode與urldecode編碼解碼詳解

    這篇文章主要給大家介紹了關(guān)于Golang中urlencode與urldecode編碼解碼的相關(guān)資料,在Go語言中轉(zhuǎn)碼操作非常方便,可以使用內(nèi)置的encoding包來快速完成轉(zhuǎn)碼操作,Go語言中的encoding包提供了許多常用的編碼解碼方式,需要的朋友可以參考下
    2023-09-09
  • Golang中Gin框架中如何定義路由詳解

    Golang中Gin框架中如何定義路由詳解

    Gin是一個(gè)用Go語言編寫的Web框架,具有高性能和易于使用的特點(diǎn),本文將結(jié)合實(shí)際案例,詳細(xì)介紹Gin框架的路由用法,有需要的小伙伴可以參考下
    2024-10-10
  • 使用golang編寫一個(gè)并發(fā)工作隊(duì)列

    使用golang編寫一個(gè)并發(fā)工作隊(duì)列

    這篇文章主要介紹了使用golang編寫一個(gè)并發(fā)工作隊(duì)列的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-05-05
  • Golang使用crypto/ed25519實(shí)現(xiàn)數(shù)字簽名和驗(yàn)證

    Golang使用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-02
  • 解讀golang plugin熱更新嘗試

    解讀golang plugin熱更新嘗試

    這篇文章主要介紹了解讀golang plugin熱更新嘗試,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-04-04
  • golang之?dāng)?shù)據(jù)驗(yàn)證validator的實(shí)現(xiàn)

    golang之?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-10
  • GOLang?IO接口與工具使用方法講解

    GOLang?IO接口與工具使用方法講解

    這篇文章主要介紹了GOLang?IO接口與工具使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-03-03
  • go語言使用jwt認(rèn)證的實(shí)現(xiàn)

    go語言使用jwt認(rèn)證的實(shí)現(xiàn)

    本文主要介紹了go語言使用jwt認(rèn)證的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04

最新評(píng)論