golang redis中Pipeline通道的使用詳解
goredis庫(kù)連接客戶端
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個(gè)過程:
發(fā)送命令 -> 命令排隊(duì) -> 命令執(zhí)行 -> 返回結(jié)果
這個(gè)過程稱為Round trip time(簡(jiǎn)稱RTT, 往返時(shí)間),mget、mset有效節(jié)約了RTT,但大部分命令不支持批量操作,需要消耗N次RTT ,這個(gè)時(shí)候需要pipeline來解決這個(gè)問題。
Pipeline 主要是一種網(wǎng)絡(luò)優(yōu)化,它本質(zhì)上意味著客戶端緩沖一堆命令并一次性將它們發(fā)送到服務(wù)器,減少了每條命令分別傳輸?shù)腎O開銷, 同時(shí)減少了系統(tǒng)調(diào)用的次數(shù),因此提升了整體的吞吐能力,節(jié)省了每個(gè)命令的網(wǎng)絡(luò)往返時(shí)間(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)
上面的代碼相當(dāng)于將以下兩個(gè)命令一次發(fā)給redis server端執(zhí)行與不使用Pipeline相比能減少一次RTT。
del test1
del test2
pipeline命令的使用
PS:如果redis采用了集群部署,不可以直接使用pipeline命令進(jìn)行操作,因?yàn)樵L問的key可能并不在同一個(gè)節(jié)點(diǎn)上
// PipelineGetHashField 使用pipeline命令獲取多個(gè)hash key的單個(gè)字段 // 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()) } /********** ?。。。。。。。。。?************/ // 注意這里如果某一次獲取時(shí)出錯(cuò)(常見的redis.Nil),返回的err即不為空 // 如果需要處理redis.Nil為默認(rèn)值,此處不能直接return } valList := make([]string, 0, len(keyList)) for index, cmdRes := range res { var val string // 此處斷言類型為在for循環(huán)內(nèi)執(zhí)行的命令返回的類型,上面HGet返回的即為*redis.StringCmd類型 // 處理方式和直接調(diào)用同樣處理即可 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 }
到此這篇關(guān)于golang redis中Pipeline通道的使用詳解的文章就介紹到這了,更多相關(guān)golang redis中Pipeline通道內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Golang輕松實(shí)現(xiàn)JWT身份驗(yàn)證的示例代碼
JSON Web Tokens (JWT)是一種流行的安全方法,用于在兩個(gè)方之間表示聲明,本文主要為大家詳細(xì)介紹了實(shí)現(xiàn)Go應(yīng)用程序中的JWT身份驗(yàn)證過程,需要的可以參考下2024-02-02go語言實(shí)現(xiàn)的memcache協(xié)議服務(wù)的方法
這篇文章主要介紹了go語言實(shí)現(xiàn)的memcache協(xié)議服務(wù)的方法,實(shí)例分析了Go語言使用memcache的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03goland把go項(xiàng)目打包進(jìn)docker鏡像的全過程記錄
golang編譯的應(yīng)用是不需要依賴其他運(yùn)行環(huán)境的,下面這篇文章主要給大家介紹了關(guān)于goland把go項(xiàng)目打包進(jìn)docker鏡像的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08Go語言CSP并發(fā)模型goroutine及channel底層實(shí)現(xiàn)原理
這篇文章主要為大家介紹了Go語言CSP并發(fā)模型goroutine?channel底層實(shí)現(xiàn)原理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05