学习本文需要一些redis知识,请学习前面文章
详细可见个人博客:https://linzyblog.netlify.app/
Redigo是Redis数据库的Go客户端。用于实现Redis数据库的基本操作,支持Redis的所有命令。
Redigo 官方地址:点击跳转
直接在在terminal里输入指令
go get github.com/gomodule/redigo/redis
Conn接口是使用Redis数据库的主要接口。通过调用redis.Dial()来创建连接。创建连接完成操作后,必须调用连接关闭方法Conn.Close()。
func main() {
//创建Redis连接
c, err := redis.Dial("tcp", "127.0.0.1:6379")
if err != nil {
log.Fatal(err)
}
//使用延迟函数,在函数结束前调用连接关闭
defer c.Close()
}
若是Redis设置了密码:
func main() {
//创建Redis连接
c, err := redis.Dial("tcp", "127.0.0.1:6379",
redis.DialUsername("username"),
redis.DialPassword("password"),
)
if err != nil {
log.Fatal(err)
}
//使用延迟函数,在函数结束前调用连接关闭
defer c.Close()
}
func Setup() error {
RedisConn = &redis.Pool{
//最大空闲连接数
MaxIdle: 30,
//在给定时间内,允许分配的最大连接数(当为零时,没有限制)
MaxActive: 30,
//在给定时间内,保持空闲状态的时间,若到达时间限制则关闭连接(当为零时,没有限制)
IdleTimeout: 200,
//提供创建和配置应用程序连接的一个函数
Dial: func() (redis.Conn, error) {
c, err := redis.Dial("tcp", "127.0.0.1:6379")
if err != nil {
return nil, err
}
//如果redis设置了用户密码,使用auth指令
if _, err := c.Do("AUTH", password); err != nil {
c.Close()
return nil, err
}
return c, err
},
TestOnBorrow: func(c redis.Conn, t time.Time) error {
_, err := c.Do("PING")
return err
},
}
return nil
}
设置 RedisConn 为 redis.Pool(连接池)并配置了它的一些参数:
- Dial:提供创建和配置应用程序连接的一个函数。
- TestOnBorrow:可选的应用程序检查连接是否健康功能。
- MaxIdle:最大空闲连接数。
- MaxActive:在给定时间内,允许分配的最大连接数(当为零时,没有限制)。
- IdleTimeout:在给定时间内,保持空闲状态的时间,若到达时间限制则关闭连接(当为零时,没有限制)。
//Do 方法将命令参数转换为批量字符串以传输到Redis服务器,交给Redis处理
//redis.String将Do操作后的返回值转换为String格式输出
s1, err := redis.String(c.Do("SET", "linzy", "18"))
if err != nil {
log.Fatal(err)
}
fmt.Println(s1)
s2, err := redis.String(c.Do("GET", "linzy"))
if err != nil {
log.Fatal(err)
}
fmt.Println(s2)
s3, err := redis.String(c.Do("GET", "linzydashuaige"))
if err != nil {
log.Fatal(err)
}
fmt.Println(s3)
可以参考我上一篇文章《Redis五大基础数据类型》,自己动手测试吧。