当前位置:首页 >综合 >Golang 官方推荐使用的 Redis 客户端 Redigo 更接近使用 redis-cli 操作 Redis

Golang 官方推荐使用的 Redis 客户端 Redigo 更接近使用 redis-cli 操作 Redis

2024-07-01 13:27:41 [百科] 来源:避面尹邢网

Golang 官方推荐使用的官方 Redis 客户端 Redigo

作者:frank 存储 存储软件 Redis 本文我们介绍了 Golang 官方推荐的操作 Redis 的三方库 redigo,它仅需使用 Do 函数执行 Redis 推荐所有命令,它还提供了很多助手函数帮助我们更加方便操作 Redis。使用

 [[414601]]

01介绍

在之前的客户文章介绍过 Golang 操作 Redis 的三方库 go-redis,本文主要介绍另外一个 Golang 操作 Redis 官方的三方库 redigo,它是推荐 Golang 官方推荐使用的 Redis 客户端。

go-redis 使用三方库为我们封装了很多函数来执行 Redis 命令,而 redigo 三方库只有一个 Do 函数执行 Redis 客户命令,更接近使用 redis-cli 操作 Redis,官方这一点是推荐我个人比较喜欢的,只要熟悉 Redis,使用就可以轻松使用 redigo 作为客户端操作 Redis,客户而不需要再去记三方库封装的官方函数。

Golang 官方推荐使用的 Redis 客户端 Redigo 更接近使用  redis-cli 操作 Redis

使用 go get 命令安装 redigo:

Golang 官方推荐使用的 Redis 客户端 Redigo 更接近使用  redis-cli 操作 Redis

  1. go get github.com/gomodule/redigo/redis 

redigo 库中的推荐 Conn 接口是操作 Redis 的主要接口。

Golang 官方推荐使用的 Redis 客户端 Redigo 更接近使用  redis-cli 操作 Redis

  1. type Conn interface {  
  2.  // Close closes the connection. 
  3.  Close() error 
  4.  // Err returns a non-nil value when the connection is not usable. 
  5.  Err() error 
  6.  // Do sends a command to the server and returns the received reply. 
  7.  Do(commandName string,使用 args ...interface{ }) (reply interface{ }, err error) 
  8.  // Send writes the command to the client's output buffer. 
  9.  Send(commandName string, args ...interface{ }) error 
  10.  // Flush flushes the output buffer to the Redis server. 
  11.  Flush() error 
  12.  // Receive receives a single reply from the Redis server 
  13.  Receive() (reply interface{ }, err error) 

阅读 redigo 库的源码,我们可以发现 Conn 接口包含 6 个方法,本文我们主要使用 Do 和 Close。

02创建连接

redigo 库提供了多个函数创建连接,本文我们使用 Dial 函数创建连接,此外,还可以使用 DialURL 函数和 NewConn 函数创建连接,限于篇幅,本文不准备逐一介绍。

示例代码:

  1. // 连接 redis-server 
  2. // 创建连接 
  3. c, err := redis.Dial("tcp", ":6379") 
  4. if err != nil {  
  5.   fmt.Printf("redis.Dial() error:%v", err) 
  6.   return 
  7. // 关闭连接 
  8. defer c.Close() 

阅读上面这段代码,我们使用 Dial 函数创建连接,需要注意的是,我们不要忘记关闭连接。

使用该方式主要是为了读者朋友们容易理解,建议在生产环境中使用连接池,避免每次执行命令都需要先创建连接,影响性能。

03string 操作

redigo 执行 Redis 命令的通用方法是使用 Conn 接口的 Do 函数,Do 函数可以发送命令给 Redis 服务器,并返回 Redis 服务器的回复。

  1. Do(commandName string, args ...interface{ }) (reply interface{ }, err error) 

示例代码:

  1. func stringSet(conn redis.Conn) {  
  2.  replySet, err := conn.Do("SET", "key1", "value1") 
  3.  if err != nil {  
  4.   fmt.Println("SET error: ", err) 
  5.  } 
  6.  fmt.Println(replySet) 

阅读上面这段代码,我们使用 Do 函数执行 Redis 的 set 命令,限于篇幅,更多关于 string 类型的 redis 命令示例代码,请阅读推送到 GitHub 的本文相关代码。

04复合类型操作

除了操作字符串,我们还会操作复合类型,redigo 库中的 Args 类型提供了操作复合类型的方法 AddFlat。

  1. func (args Args) AddFlat(v interface{ }) Args 

写操作:

  1. type User struct {  
  2.  ID   int64  `redis:"id"` 
  3.  Name string `redis:"name"` 
  4.  
  5. // struct 
  6. func structAdd(conn redis.Conn) {  
  7.  u1 := User{  
  8.   ID:   1, 
  9.   Name: "name1", 
  10.  } 
  11.  
  12.  replyStruct, err := conn.Do("HMSET", redis.Args{ }.Add("hkey1").AddFlat(&u1)...) 
  13.  if err != nil {  
  14.   fmt.Println("struct err: ", err) 
  15.  } 
  16.  fmt.Println(replyStruct) 

阅读上面这段代码,我们使用 AddFlat 方法将结构体写入 Redis,需要注意的是结构体字段是可导出的字段名称,并且使用了字段标签 redis。

读操作:

  1. func structValues(conn redis.Conn) {  
  2.  v, err := redis.Values(conn.Do("HGETALL", "hkey1")) 
  3.  if err != nil {  
  4.   fmt.Println("redis.Values() err: ", err) 
  5.  } 
  6.  
  7.  // redis.ScanStruct() 
  8.  u2 := new(User) 
  9.  if err := redis.ScanStruct(v, u2); err != nil {  
  10.   fmt.Println("redis.ScanStruct() err: ", err) 
  11.  } 
  12.  
  13.  fmt.Printf("%+v\n", u2) 

阅读上面这段代码,我们使用两个助手函数 Values 和 ScanStruct,将 Redis 服务器的回复解析到 struct,redigo 还提供了助手函数 ScanSlice 将 Redis 服务器的回复解析到 slice。

限于篇幅,关于 map 和 slice 的示例代码,请阅读推送到 GitHub 上的本文相关代码。

05总结

本文我们介绍了 Golang 官方推荐的操作 Redis 的三方库 redigo,它仅需使用 Do 函数执行 Redis 所有命令,它还提供了很多助手函数帮助我们更加方便操作 Redis。

本文转载自微信公众号「Golang语言开发栈」,可以通过以下二维码关注。转载本文请联系Golang语言开发栈公众号。

 

责任编辑:武晓燕 来源: Golang语言开发栈 Redis Golang命令

(责任编辑:休闲)

    推荐文章
    热点阅读