目录
安装redis库
go get github.com/gomodule/redigo/redis
【1】set get操作
package main
import (
"fmt"
"github.com/gomodule/redigo/redis"
)
func main() {
//连接redis
conn, err := redis.Dial("tcp",
"127.0.0.1:6379",
redis.DialDatabase(1),//dialOption参数可以配置选择数据库、连接密码、心跳检测等等
redis.DialPassword("secret_redis")) //密码
if err != nil {
fmt.Println("conn redis failed,", err)
return
}
defer conn.Close()
//向redis写入数据
_, err = conn.Do("set", "go_test_name", "tom")
if err != nil {
fmt.Println("set failed,", err)
return
}
//从redis读取数据
//返回的是interface{} 所以要通过redis.String()转成string
r, err := redis.String(conn.Do("get", "go_test_name"))
if err != nil {
fmt.Println("get failed,", err)
return
}
fmt.Println("r = ", r)
//设置过期时间 10s
_, err = conn.Do("setex", "go_test_ex_name", 10, "tom")
if err != nil {
fmt.Println("set failed,", err)
return
}
}
【2】设置过期时间
//设置过期时间
conn.Do("expire", "go_test_users", 10)
【3】hash批量操作
conn.Do("hMSet", "go_test_user02", "name", "lucy", "age", 19)
//因为是操作多个 所以要用 redis.Strings
user, _ := redis.Strings(conn.Do("hMGet", "go_test_user02", "name", "age"))
for i, v := range user {
fmt.Printf("user[%v] = %v\n", i, v)
}
【4】连接池
Redis链接池
说明: 通过Golang 对Redis操作, 还可以通过Redis链接池,流程如下:
1、事先初始化一定数量的链接,放入到链接池
2、当Go需要操作Redis时,直接从Redis链接池取出链接即可。
3、这样可以节省临时获取Redis链接的时间,从而提高效率.
package main
import (
"fmt"
"github.com/gomodule/redigo/redis"
)
// 定义一个全局的pool
var pool *redis.Pool
// 启动程序时,初始化连接池
func init() {
pool = &redis.Pool{
MaxIdle: 8, //最大空闲连接数
MaxActive: 0, //表示和数据库的最大连接数,0:无限制
IdleTimeout: 100, //最大空闲时间 秒
Dial: func() (redis.Conn, error) { //初始化连接的代码
return redis.Dial("tcp",
"127.0.0.1:6379",
redis.DialDatabase(1), //dialOption参数可以配置选择数据库、连接密码、心跳检测等等
redis.DialPassword("secret_redis")) //密码
},
}
}
func main() {
//从pool中取出一个连接
conn := pool.Get()
//把连接放回连接池
defer conn.Close()
_, err := conn.Do("set", "name", "祥子")
if err != nil {
fmt.Println("conn set err=", err)
return
}
name, err := redis.String(conn.Do("get", "name"))
if err != nil {
fmt.Println("conn get err=", err)
return
}
fmt.Println("name = ", name)
}