一、什么是連接池,連接池有什么用
先看看別人是怎么介紹連接池的吧:
連接池基本的思想是在系統(tǒng)初始化的時候,將數(shù)據(jù)庫連接作為對象存儲在內(nèi)存中,當(dāng)用戶需要訪問數(shù)據(jù)庫時,并非建立一個新的連接,而是從連接池中取出一個已建立的空閑連接對象。使用完畢后,用戶也并非將連接關(guān)閉,而是將連接放回連接池中,以供下一個請求訪問使用。而連接的建立、斷開都由連接池自身來管理。同時,還可以通過設(shè)置連接池的參數(shù)來控制連接池中的初始連接數(shù)、連接的上下限數(shù)以及每個連接的最大使用次數(shù)、最大空閑時間等等。也可以通過其自身的管理機制來監(jiān)視數(shù)據(jù)庫連接的數(shù)量、使用情況等。
下面我來簡單解釋一下,因為每次Redis客戶端連接Redis服務(wù)端都需要一段時間,而處理各種操作的時間很多時候都很短,如果每次進行各種操作時都需要重新連接Redis,那么就會浪費大量時間。因此Redis引入連接池,連接池可以實現(xiàn)建立多個客戶端連接而不釋放,避免浪費IO資源,不使用的時候就放在連接池,這樣就減少了連接數(shù)據(jù)庫所需要的時間,提高效率。
連接池就是建一個池子和一定量的管道。每次當(dāng)管道被取盡時,就不能繼續(xù)消耗IO資源了,這樣就保證了IO資源不會耗盡。
二、代碼展示
package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
"strconv"
"time"
)
func main() {
pool := redis.Pool{
// Maximum number of connections allocated by the pool at a given time.
// When zero, there is no limit on the number of connections in the pool.
//最大活躍連接數(shù),0代表無限
MaxActive: 888,
//最大閑置連接數(shù)
// Maximum number of idle connections in the pool.
MaxIdle: 20,
//閑置連接的超時時間
// Close connections after remaining idle for this duration. If the value
// is zero, then idle connections are not closed. Applications should set
// the timeout to a value less than the server's timeout.
IdleTimeout: time.Second * 100,
//定義撥號獲得連接的函數(shù)
// Dial is an application supplied function for creating and configuring a
// connection.
//
// The connection returned from Dial must not be in a special state
// (subscribed to pubsub channel, transaction started, ...).
Dial: func() (redis.Conn, error) {
return redis.Dial("tcp","127.0.0.1:6379"),
}
}
//延遲關(guān)閉連接池
defer pool.Close()
//IO并發(fā)連接
for i:=0;i10;i++{
go getConnFromPoolAndHappy(pool,i)
}
//保持主協(xié)程存活
time.Sleep(3*time.Second)
}
func getConnFromPoolAndHappy(pool *redis.Pool, i int) {
//通過連接池獲得連接
conn := pool.Get()
//延時關(guān)閉連接
defer conn.Close()
//使用連接操作數(shù)據(jù)
reply, err := conn.Do("set", "conn"+strconv.Itoa(i), i)
s, _ := redis.String(reply, err)
fmt.Println(s)
}
MaxActive: 888
上面的代碼表示在給定的時間內(nèi)被連接池分配的最大連接數(shù),當(dāng)該值為0時,表示連接池的連接數(shù)是無上限的。
MaxIdle: 20
表示連接池閑置連接數(shù)的上限。
IdleTimeout: time.Second * 100
該值表示如果連接池的的連接閑置超過該值就會關(guān)閉連接。如果該值為零,連接池中閑置的連接就不會關(guān)閉。應(yīng)用程序應(yīng)該設(shè)置這個限制超時時間不超過服務(wù)端的限制超時時間。
Dial: func() (redis.Conn, error) {
return redis.Dial("tcp", "127.0.0.1:6379")
}
該值為一個函數(shù),該函數(shù)應(yīng)該用于創(chuàng)造和配置連接。從Dial返回的連接不能處于特殊狀態(tài)。
開辟一條并發(fā)協(xié)程執(zhí)行該函數(shù),因為for循環(huán)的范圍是0-9,所以并發(fā)數(shù)為10,表示同時有10個人去連接池取管道。
go getConnFromPoolAndHappy(pool,i)
下列代碼是用來保持主協(xié)程存活的。
time.Sleep(3*time.Second)
下面表示通過連接池獲得連接。也就是從池子拿一根管道。
然后下面的代碼是使用管道。
reply, err := conn.Do("set", "conn"+strconv.Itoa(i), i)
s, _ := redis.String(reply, err)
fmt.Println(s)
如果一個人占著管道不用,就會被閑置。如果在閑置處太久不動,達到閑置連接的超時時間,就會被請走。
因為池子使用的都是同一個,所以需要使用池子的指針。
到此這篇關(guān)于Go實現(xiàn)Redis連接池方法的文章就介紹到這了,更多相關(guān)Go Redis連接池內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!