Go實(shí)現(xiàn)Redis連接池方法
一、什么是連接池,連接池有什么用
先看看別人是怎么介紹連接池的吧:
連接池基本的思想是在系統(tǒng)初始化的時(shí)候,將數(shù)據(jù)庫(kù)連接作為對(duì)象存儲(chǔ)在內(nèi)存中,當(dāng)用戶需要訪問數(shù)據(jù)庫(kù)時(shí),并非建立一個(gè)新的連接,而是從連接池中取出一個(gè)已建立的空閑連接對(duì)象。使用完畢后,用戶也并非將連接關(guān)閉,而是將連接放回連接池中,以供下一個(gè)請(qǐng)求訪問使用。而連接的建立、斷開都由連接池自身來管理。同時(shí),還可以通過設(shè)置連接池的參數(shù)來控制連接池中的初始連接數(shù)、連接的上下限數(shù)以及每個(gè)連接的最大使用次數(shù)、最大空閑時(shí)間等等。也可以通過其自身的管理機(jī)制來監(jiān)視數(shù)據(jù)庫(kù)連接的數(shù)量、使用情況等。
下面我來簡(jiǎn)單解釋一下,因?yàn)槊看蜶edis客戶端連接Redis服務(wù)端都需要一段時(shí)間,而處理各種操作的時(shí)間很多時(shí)候都很短,如果每次進(jìn)行各種操作時(shí)都需要重新連接Redis,那么就會(huì)浪費(fèi)大量時(shí)間。因此Redis引入連接池,連接池可以實(shí)現(xiàn)建立多個(gè)客戶端連接而不釋放,避免浪費(fèi)IO資源,不使用的時(shí)候就放在連接池,這樣就減少了連接數(shù)據(jù)庫(kù)所需要的時(shí)間,提高效率。
連接池就是建一個(gè)池子和一定量的管道。每次當(dāng)管道被取盡時(shí),就不能繼續(xù)消耗IO資源了,這樣就保證了IO資源不會(huì)耗盡。
二、代碼展示
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, //閑置連接的超時(shí)時(shí)間 // 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, //定義撥號(hào)獲得連接的函數(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;i<10;i++{ go getConnFromPoolAndHappy(pool,i) } //保持主協(xié)程存活 time.Sleep(3*time.Second) } func getConnFromPoolAndHappy(pool *redis.Pool, i int) { //通過連接池獲得連接 conn := pool.Get() //延時(shí)關(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
上面的代碼表示在給定的時(shí)間內(nèi)被連接池分配的最大連接數(shù),當(dāng)該值為0時(shí),表示連接池的連接數(shù)是無上限的。
MaxIdle: 20
表示連接池閑置連接數(shù)的上限。
IdleTimeout: time.Second * 100
該值表示如果連接池的的連接閑置超過該值就會(huì)關(guān)閉連接。如果該值為零,連接池中閑置的連接就不會(huì)關(guān)閉。應(yīng)用程序應(yīng)該設(shè)置這個(gè)限制超時(shí)時(shí)間不超過服務(wù)端的限制超時(shí)時(shí)間。
Dial: func() (redis.Conn, error) { return redis.Dial("tcp", "127.0.0.1:6379") }
該值為一個(gè)函數(shù),該函數(shù)應(yīng)該用于創(chuàng)造和配置連接。從Dial返回的連接不能處于特殊狀態(tài)。
開辟一條并發(fā)協(xié)程執(zhí)行該函數(shù),因?yàn)閒or循環(huán)的范圍是0-9,所以并發(fā)數(shù)為10,表示同時(shí)有10個(gè)人去連接池取管道。
go getConnFromPoolAndHappy(pool,i)
下列代碼是用來保持主協(xié)程存活的。
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)
如果一個(gè)人占著管道不用,就會(huì)被閑置。如果在閑置處太久不動(dòng),達(dá)到閑置連接的超時(shí)時(shí)間,就會(huì)被請(qǐng)走。
因?yàn)槌刈邮褂玫亩际峭粋€(gè),所以需要使用池子的指針。
pool := &redis.Pool
到此這篇關(guān)于Go實(shí)現(xiàn)Redis連接池方法的文章就介紹到這了,更多相關(guān)Go Redis連接池內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
golang使用http client發(fā)起get和post請(qǐng)求示例
這篇文章主要介紹了golang使用http client發(fā)起get和post請(qǐng)求示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02Go語言實(shí)現(xiàn)AzDG可逆加密算法實(shí)例
這篇文章主要介紹了Go語言實(shí)現(xiàn)AzDG可逆加密算法,實(shí)例分析了AzDG可逆加密算法的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02通過案例簡(jiǎn)單聊聊為什么說Go中的字符串是不能被修改的
在接觸Go這么語言,可能你經(jīng)常會(huì)聽到這樣一句話,對(duì)于字符串不能修改,可能你很納悶,日常開發(fā)中我們對(duì)字符串進(jìn)行修改也是很正常的,為什么又說Go中的字符串不能進(jìn)行修改呢,本文就來通過實(shí)際案例給大家演示,為什么Go中的字符串不能進(jìn)行修改2023-07-07go實(shí)現(xiàn)整型的二進(jìn)制轉(zhuǎn)化的方法
這篇文章主要介紹了go實(shí)現(xiàn)整型的二進(jìn)制轉(zhuǎn)化的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-07-07