網站首頁 編程語言 正文
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出現的背景
redis客戶端執行一條命令分4個過程:
發送命令 -> 命令排隊 -> 命令執行 -> 返回結果
這個過程稱為Round trip time(簡稱RTT, 往返時間),mget、mset有效節約了RTT,但大部分命令不支持批量操作,需要消耗N次RTT ,這個時候需要pipeline來解決這個問題。
Pipeline 主要是一種網絡優化,它本質上意味著客戶端緩沖一堆命令并一次性將它們發送到服務器,減少了每條命令分別傳輸的IO開銷, 同時減少了系統調用的次數,因此提升了整體的吞吐能力,節省了每個命令的網絡往返時間(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)
上面的代碼相當于將以下兩個命令一次發給redis server端執行與不使用Pipeline相比能減少一次RTT。
del test1
del test2
pipeline命令的使用
PS:如果redis采用了集群部署,不可以直接使用pipeline命令進行操作,因為訪問的key可能并不在同一個節點上
// 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循環內執行的命令返回的類型,上面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 }
原文鏈接:https://blog.csdn.net/lff1123/article/details/124782312
相關推薦
- 2022-04-11 error: failed to push some refs to如何解決
- 2022-04-28 shell命令返回值判斷的方法實現_linux shell
- 2022-06-21 C語言分別實現棧和隊列詳解流程_C 語言
- 2023-07-07 關于啟動報錯ModuleNotFoundError:No module named ‘python-
- 2022-11-24 詳解如何實現一個Kotlin函數類型_Android
- 2023-03-26 rollup?cli開發全面系統性rollup源碼分析_其它
- 2024-07-18 Spring Security之認證信息的處理
- 2023-04-06 關于yolov8訓練的一些改動及注意事項_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支