Go實現Redis連接池方法
一、什麼是連接池,連接池有什麼用
先看看別人是怎麼介紹連接池的吧:
連接池基本的思想是在系統初始化的時候,將數據庫連接作為對象存儲在內存中,當用戶需要訪問數據庫時,並非建立一個新的連接,而是從連接池中取出一個已建立的空閑連接對象。使用完畢後,用戶也並非將連接關閉,而是將連接放回連接池中,以供下一個請求訪問使用。而連接的建立、斷開都由連接池自身來管理。同時,還可以通過設置連接池的參數來控制連接池中的初始連接數、連接的上下限數以及每個連接的最大使用次數、最大空閑時間等等。也可以通過其自身的管理機制來監視數據庫連接的數量、使用情況等。
下面我來簡單解釋一下,因為每次Redis客戶端連接Redis服務端都需要一段時間,而處理各種操作的時間很多時候都很短,如果每次進行各種操作時都需要重新連接Redis,那麼就會浪費大量時間。因此Redis引入連接池,連接池可以實現建立多個客戶端連接而不釋放,避免浪費IO資源,不使用的時候就放在連接池,這樣就減少瞭連接數據庫所需要的時間,提高效率。
連接池就是建一個池子和一定量的管道。每次當管道被取盡時,就不能繼續消耗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. //最大活躍連接數,0代表無限 MaxActive: 888, //最大閑置連接數 // 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, //定義撥號獲得連接的函數 // 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"), } } //延遲關閉連接池 defer pool.Close() //IO並發連接 for i:=0;i<10;i++{ go getConnFromPoolAndHappy(pool,i) } //保持主協程存活 time.Sleep(3*time.Second) } func getConnFromPoolAndHappy(pool *redis.Pool, i int) { //通過連接池獲得連接 conn := pool.Get() //延時關閉連接 defer conn.Close() //使用連接操作數據 reply, err := conn.Do("set", "conn"+strconv.Itoa(i), i) s, _ := redis.String(reply, err) fmt.Println(s) }
MaxActive: 888
上面的代碼表示在給定的時間內被連接池分配的最大連接數,當該值為0時,表示連接池的連接數是無上限的。
MaxIdle: 20
表示連接池閑置連接數的上限。
IdleTimeout: time.Second * 100
該值表示如果連接池的的連接閑置超過該值就會關閉連接。如果該值為零,連接池中閑置的連接就不會關閉。應用程序應該設置這個限制超時時間不超過服務端的限制超時時間。
Dial: func() (redis.Conn, error) { return redis.Dial("tcp", "127.0.0.1:6379") }
該值為一個函數,該函數應該用於創造和配置連接。從Dial返回的連接不能處於特殊狀態。
開辟一條並發協程執行該函數,因為for循環的范圍是0-9,所以並發數為10,表示同時有10個人去連接池取管道。
go getConnFromPoolAndHappy(pool,i)
下列代碼是用來保持主協程存活的。
time.Sleep(3*time.Second)
下面表示通過連接池獲得連接。也就是從池子拿一根管道。
conn := pool.Get()
然後下面的代碼是使用管道。
reply, err := conn.Do("set", "conn"+strconv.Itoa(i), i) s, _ := redis.String(reply, err) fmt.Println(s)
如果一個人占著管道不用,就會被閑置。如果在閑置處太久不動,達到閑置連接的超時時間,就會被請走。
因為池子使用的都是同一個,所以需要使用池子的指針。
pool := &redis.Pool
到此這篇關於Go實現Redis連接池方法的文章就介紹到這瞭,更多相關Go Redis連接池內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- go redis之redigo的使用
- 使用go net實現簡單的redis通信協議
- 一文搞懂Go語言操作Redis的方法
- Go Redis客戶端使用的兩種對比
- Go語言開發redis封裝及簡單使用詳解