2022/02/17
redis 链接池
最近公司工作还是有点忙的,学的慢了点~~~~,到这里,go语言基本是学完了基础篇了。
下面做项目增强码力了!
package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
)
/*
redis 链接池
1.实现初始化一定数量的链接,放入到链接池
2.当GO需要操作Redis时,直接从Redis链接池取出链接即可
3.这样可以节省临时获取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")
},
}
c := pool.Get() //从链接池中取出一个链接
pool.Close() //关闭链接池后,就不能再从链接池中再取链接
*/
//定义一个全局的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() {
//先从pool取出一个链接
conn := pool.Get()
defer conn.Close()
//放入数据
_, err1 := conn.Do("Set", "name", "Levi")
if err1 != nil {
fmt.Println("set err , err = ", err1)
return
}
//取出数据
ret1, err2 := redis.String(conn.Do("Get", "name"))
if err2 != nil {
fmt.Println("Get err , err = ", err2)
return
}
fmt.Println("Get success , name = ", ret1)
//如果我们要从pool取出链接,一定要保证链接池是没有关闭
pool.Close()
/*
这里只是个引用,在Do的时候才会真正去取
*/
conn2 := pool.Get()
fmt.Println("conn2 = ", conn2) //output: conn2 = {0xc0000507a0}
ret2, err3 := redis.String(conn2.Do("Get", "name"))
if err3 != nil {
fmt.Println("Get err , err = ", err3) //Get err , err = redigo: get on closed pool
return
}
fmt.Println("Get success , name = ", ret2)
}