Go语言操作Redis

Posted 张志翔ۤ

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Go语言操作Redis相关的知识,希望对你有一定的参考价值。

        最近工作中有使用到通过Go语言操作Redis相关内容,特此记录便于日后查阅。

        1、获取Golang的redis第三方api

  $ git clone https://github.com/garyburd/redigo.git

        2、获取redis连接 & Set/Get接口

package main

import (
	"fmt"
	"github.com/garyburd/redigo/redis"  // 引入redis包
)

func main() {

	// 通过go向redis写入数据和读取数据
	// 1.连接到redis
	conn, err := redis.Dial("tcp", "127.0.0.1:6379")
	if err != nil {
		fmt.Println("redis connect failed. err = ", err)
		return
	}
	defer conn.Close() //关闭连接

	// 2.通过go向redis写入数据
	_, err = conn.Do("Set", "name", "tomjerry")
	if err != nil {
		fmt.Println("Set err = ", err)
		return
	}

	// 3.从redis中读取数据
	// 由于返回的r是一个interface{},故要转成字符串
	r, err := redis.String(conn.Do("Get", "name"))
	if err != nil {
		fmt.Println("Get err = ", err)
		return
	}
	fmt.Println("操作ok. name =", r)  // 操作ok. name = tomjerry
}

        3、批量HMSet/HMGet

package main

import (
	"fmt"
	"github.com/garyburd/redigo/redis"  // 引入redis包
)

func main() {

	// 通过go向redis写入数据和读取数据
	// 1.连接到redis
	conn, err := redis.Dial("tcp", "127.0.0.1:6379")
	if err != nil {
		fmt.Println("redis connect failed. err = ", err)
		return
	}
	defer conn.Close() //关闭连接

	// 2.通过go向redis写入数据
	_, err = conn.Do("HMSet", "user01", "name", "jack", "age", 20)
	if err != nil {
		fmt.Println("HMSet err = ", err)
		return
	}

	// 3.从redis中读取数据
	// 由于返回的r是一个多类型的变量,故需要用redis.Strings()
	r, err := redis.Strings(conn.Do("HMGet", "user01", "name", "age"))
	if err != nil {
		fmt.Println("HMGet err = ", err)
		return
	}
	// 遍历结果
	for i, v := range r {
		fmt.Printf("r[%d]=%v\\n", i, v)
	}
	/*
	r[0]=jack
	r[1]=20
	*/
}

        4、设置数据有效时间

_, err = conn.Do("MSet", "name01", "RSQ", "name02", "Tom")
if err != nil {
	fmt.Println("HMSet err = ", err)
	return
}
// 设置超时时间
_, err = conn.Do("expire", "name01", 10)
if err != nil {
	fmt.Println("Set Expire err = ", err)
	return
}

        5、操作List

// 1.通过go向redis写入数据
_, err = conn.Do("Lpush", "herolist", "no1:宋江", 30, "no2:吴淞", 40)
if err != nil {
	fmt.Println("Lpush err = ", err)
	return
}

// 2.从redis中读取数据
r, err = redis.String(conn.Do("rpop", "herolist"))
if err != nil {
	fmt.Println("rpop err = ", err)
	return
}

        6、redis连接池

package main

import (
	"fmt"
	"github.com/garyburd/redigo/redis"
)
// 定义一个全局的pool
var pool *redis.Pool

// 创建连接池
func init()  {
	pool = &redis.Pool{
		MaxIdle: 8,  // 表示最大空闲连接数
		MaxActive: 0,	// 表示和数据库的最大连接数,0表示没有限制
		IdleTimeout: 100,	// 最大空闲时间
		Dial: func() (redis.Conn, error) {  // 初始化连接的代码,连接哪个ip的redis
			return redis.Dial("tcp", "localhost:6379")
		},
	}
}

func main() {

	conn := pool.Get()  // 从连接池中取出一个连接
	defer conn.Close()  // 关闭连接池,一旦关闭连接池,就不能从连接池再取出连接

	_, err := conn.Do("set", "car", "BBB")
	if err != nil {
		fmt.Println("conn.Do err=", err)
		return
	}

	r, err := redis.String(conn.Do("Get", "car"))
	if err != nil {
		fmt.Println("read Data err=", err)
		return
	}

	fmt.Println("r=", r)
	// 如果要从pool池中取出连接,一定要保证连接池是没有关闭的

}

        7、redis操作实战

  1. Monster信息[name, age, skill]
  2. 通过终端输入三个monster的信息,使用golang操作redis,存放到redis中[用hash数据类型]
  3. 遍历出所有的Monster信息,并显示在终端
  4. 保存monster可以使用hash数据类型,遍历时先取出所有的keys,比如keys monster*
package main

import (
	"fmt"
	"github.com/garyburd/redigo/redis"
)

type Monster struct {
	Name string
	Age int
	Skill string
}

func Process(name string, age int, skill string) {

	// 1.连接redis
	conn, err := redis.Dial("tcp", "127.0.0.1:6379")
	if err != nil {
		fmt.Println("conn err = ", err)
		return
	}
	defer conn.Close()

	// 2.往redis数据库写入数据
	_, err = conn.Do("HMset", "monster", "name", name, "age", age, "skill", skill)
	if err != nil {
		fmt.Println("write data err = ", err)
		return
	}

	// 3.从redis中读取数据
	r, err := redis.Strings(conn.Do("HMget", "monster", "name", "age", "skill"))
	if err != nil {
		fmt.Println("read data err = ", err)
		return
	}
	for i, v := range r {
		fmt.Printf("r[%d]=%v\\n", i, v)
	}

}

func main() {

	// 定义结构体实例
	var monster Monster
	fmt.Println("请输入monster的Name:")
	fmt.Scanln(&monster.Name)
	fmt.Println("请输入monster的Age:")
	fmt.Scanln(&monster.Age)
	fmt.Println("请输入monster的Skill:")
	fmt.Scanln(&monster.Skill)

	Process(monster.Name, monster.Age, monster.Skill)

}

        到此 Golang语言操作Redis介绍完成。

以上是关于Go语言操作Redis的主要内容,如果未能解决你的问题,请参考以下文章

Go语言操作Redis

Go语言操作Redis

Go语言操作Redis

Go语言操作Redis

go语言操作Redis详细步骤

你知道的Go切片扩容机制可能是错的