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

golang redis中Pipeline通道的使用詳解

 更新時間:2022年06月02日 11:29:59   作者:sweey_lff  
本文主要介紹了golang redis中Pipeline通道的使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

goredis庫連接客戶端

package client
import (
?? ?"github.com/go-redis/redis"
?? ?"github.com/sirupsen/logrus"
)

var MainRDS *redis.Client
func init() {
?? ?ConnectRedis()
}
func ConnectRedis() {
?? ?MainRDS = redis.NewClient(&redis.Options{Addr: "127.0.0.1:6379", Password: "******"})
?? ?err := MainRDS.Ping().Err()
?? ?if err != nil {
?? ??? ?logrus.Infof("[ConnectRedis]connect redis error:%s", err.Error())
?? ??? ?panic("init client error")
?? ?}
}

一、pipeline出現(xiàn)的背景

redis客戶端執(zhí)行一條命令分4個過程:

發(fā)送命令 -> 命令排隊 -> 命令執(zhí)行 -> 返回結果

這個過程稱為Round trip time(簡稱RTT, 往返時間),mget、mset有效節(jié)約了RTT,但大部分命令不支持批量操作,需要消耗N次RTT ,這個時候需要pipeline來解決這個問題。

Pipeline 主要是一種網絡優(yōu)化,它本質上意味著客戶端緩沖一堆命令并一次性將它們發(fā)送到服務器,減少了每條命令分別傳輸?shù)腎O開銷, 同時減少了系統(tǒng)調用的次數(shù),因此提升了整體的吞吐能力,節(jié)省了每個命令的網絡往返時間(RTT)。

二、pipeline的用法

Pipeline 基本示例如下:

pipe := Redis.Pipeline()
pipe.Del(context.Background(), "test1")
pipe.Del(context.Background(), "test2")
ret, err := pipe.Exec(context.Background())
fmt.Println(ret, err)

上面的代碼相當于將以下兩個命令一次發(fā)給redis server端執(zhí)行與不使用Pipeline相比能減少一次RTT。

del test1
del test2

pipeline命令的使用

PS:如果redis采用了集群部署,不可以直接使用pipeline命令進行操作,因為訪問的key可能并不在同一個節(jié)點上

// PipelineGetHashField 使用pipeline命令獲取多個hash key的單個字段
// keyList,需要獲取的hash key列表
// field 需要獲取的字段值
func PipelineGetHashField(keyList []string,filed string) []string {
    pipeClient :=client.MainRDS.Pipeline()
    for _, key := range keyList {
        pipeClient.HGet(key, filed)
    }
    res, err := pipeClient.Exec()
    if err != nil {
        if err != redis.Nil {
            logrus.WithField("key_list", keyList).Errorf("[PipelineGetHashField] get from redis error:%s", err.Error())
        }
        /********** ?。。。。。。。。?!*************/
        // 注意這里如果某一次獲取時出錯(常見的redis.Nil),返回的err即不為空
        // 如果需要處理redis.Nil為默認值,此處不能直接return
    }
    valList := make([]string, 0, len(keyList))
    for index, cmdRes := range res {
        var val string
        // 此處斷言類型為在for循環(huán)內執(zhí)行的命令返回的類型,上面HGet返回的即為*redis.StringCmd類型
        // 處理方式和直接調用同樣處理即可
        cmd, ok := cmdRes.(*redis.StringCmd) 
        if ok {
            val,err = cmd.Result()
            if err != nil {
                logrus.WithField("key",keyList[index]).Errorf("[PipelineGetHashField] get key error:%s",err.Error())
            }
        }
        valList = append(valList, val)
    }
    return valList
}

到此這篇關于golang redis中Pipeline通道的使用詳解的文章就介紹到這了,更多相關golang redis中Pipeline通道內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 使用Golang輕松實現(xiàn)JWT身份驗證的示例代碼

    使用Golang輕松實現(xiàn)JWT身份驗證的示例代碼

    JSON Web Tokens (JWT)是一種流行的安全方法,用于在兩個方之間表示聲明,本文主要為大家詳細介紹了實現(xiàn)Go應用程序中的JWT身份驗證過程,需要的可以參考下
    2024-02-02
  • Golang?Makefile示例深入講解使用

    Golang?Makefile示例深入講解使用

    一次偶然的機會,在?github?上看到有人用?Makefile,就嘗試了一下,發(fā)現(xiàn)真的非常合適,Makefile?本身就是用來描述依賴的,可讀性非常好,而且與強大的?shell?結合在一起,基本可以實現(xiàn)任何想要的功能
    2023-01-01
  • 一文帶你掌握Golang基礎之通道

    一文帶你掌握Golang基礎之通道

    在Java中,多線程之間的通信方式有哪些?記得嗎?Java多線程間通信的解決方案有很多種,比如:synchronized。在go中,就一種:通道,文中介紹的非常詳細,感興趣的同學可以參考下
    2023-05-05
  • Go語言原子操作atomic的使用

    Go語言原子操作atomic的使用

    本文介紹了Go語言原子操作的使用方法,原子操作是一種無鎖的技術,可通過CPU指令實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-10-10
  • Golang字符串的拼接方法匯總

    Golang字符串的拼接方法匯總

    字符串拼接在日常開發(fā)中是很常見的需求,今天我們來探討下如何用golang來實現(xiàn)字符串的拼接
    2018-10-10
  • go語言實現(xiàn)的memcache協(xié)議服務的方法

    go語言實現(xiàn)的memcache協(xié)議服務的方法

    這篇文章主要介紹了go語言實現(xiàn)的memcache協(xié)議服務的方法,實例分析了Go語言使用memcache的技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-03-03
  • goland把go項目打包進docker鏡像的全過程記錄

    goland把go項目打包進docker鏡像的全過程記錄

    golang編譯的應用是不需要依賴其他運行環(huán)境的,下面這篇文章主要給大家介紹了關于goland把go項目打包進docker鏡像的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • Go語言CSP并發(fā)模型goroutine及channel底層實現(xiàn)原理

    Go語言CSP并發(fā)模型goroutine及channel底層實現(xiàn)原理

    這篇文章主要為大家介紹了Go語言CSP并發(fā)模型goroutine?channel底層實現(xiàn)原理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • GO中優(yōu)雅編碼與降低圈復雜度詳析

    GO中優(yōu)雅編碼與降低圈復雜度詳析

    Go語法簡單易用,有其他編程經驗的開發(fā)者,相信學習并快速上手Go語言的開發(fā),多數(shù)覺得不困難吧,下面這篇文章主要給大家介紹了關于GO中優(yōu)雅編碼與降低圈復雜度的相關資料,需要的朋友可以參考下
    2022-12-12
  • golang 隨機數(shù)的兩種方式

    golang 隨機數(shù)的兩種方式

    本文主要介紹了golang 隨機數(shù)的兩種方式,一種是偽隨機,另一種是真隨機,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07

最新評論