溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

golang?redis中Pipeline通道如何使用

發(fā)布時間:2022-06-02 13:42:02 來源:億速云 閱讀:624 作者:iii 欄目:開發(fā)技術

本文小編為大家詳細介紹“golang redis中Pipeline通道如何使用”,內容詳細,步驟清晰,細節(jié)處理妥當,希望這篇“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 主要是一種網(wǎng)絡優(yōu)化,它本質上意味著客戶端緩沖一堆命令并一次性將它們發(fā)送到服務器,減少了每條命令分別傳輸?shù)腎O開銷, 同時減少了系統(tǒng)調用的次數(shù),因此提升了整體的吞吐能力,節(jié)省了每個命令的網(wǎng)絡往返時間(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通道如何使用”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI