一.介绍
说明:通过golang对redis操作,还可以通过redis连接池,流程如下:
- 事先初始化一定数量的连接,放入到连接池。
- 当go需要操作redis时,直接从redis连接池取出连接即可。
- 这样可以节省临时获取redis连接的时间,从而提高效率。
二.核心代码:
var pool *redis.Pool
pool =&redis.Pool{
MaxIdle:8,//最大空闲连接数
MaxActive:0,//表示和数据库的最大连接数,0表示没有限制
IdleTimeout:100,//最大空闲时间
Dial: func() (redis.Conn, error) {//初始化连接,连接到哪个ip的redis数据库
return redis.Dial("tcp","localhost:6379")
},
}
con := pool.Get()//先从pool取出一个连接
pool.Close()//关闭连接池
三.连接池案例:
package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
)
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() {
con := pool.Get()//先从pool取出一个连接
defer con.Close()//延迟关闭连接
_,err := con.Do("Set","name","小米")
if err != nil{
fmt.Println("set失败")
return
}
reply,err :=redis.String(con.Do("Get","name"))
if err != nil{
fmt.Println("get失败")
return
}
fmt.Println("名字:",reply)
}
执行结果: