濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > Go實(shí)現(xiàn)Redis連接池方法

Go實(shí)現(xiàn)Redis連接池方法

熱門(mén)標(biāo)簽:開(kāi)通400電話申請(qǐng)流程 上海企業(yè)外呼系統(tǒng)排名 武漢百應(yīng)人工智能電銷(xiāo)機(jī)器人 百度地圖標(biāo)注位置網(wǎng)站 如何利用高德地圖標(biāo)注家 智能語(yǔ)音電銷(xiāo)的機(jī)器人 揚(yáng)州電銷(xiāo)外呼系統(tǒng)軟件 電腦外呼系統(tǒng)輻射大嗎 400手機(jī)電話免費(fèi)辦理

一、什么是連接池,連接池有什么用

先看看別人是怎么介紹連接池的吧:

連接池基本的思想是在系統(tǒng)初始化的時(shí)候,將數(shù)據(jù)庫(kù)連接作為對(duì)象存儲(chǔ)在內(nèi)存中,當(dāng)用戶(hù)需要訪問(wèn)數(shù)據(jù)庫(kù)時(shí),并非建立一個(gè)新的連接,而是從連接池中取出一個(gè)已建立的空閑連接對(duì)象。使用完畢后,用戶(hù)也并非將連接關(guān)閉,而是將連接放回連接池中,以供下一個(gè)請(qǐng)求訪問(wèn)使用。而連接的建立、斷開(kāi)都由連接池自身來(lái)管理。同時(shí),還可以通過(guò)設(shè)置連接池的參數(shù)來(lái)控制連接池中的初始連接數(shù)、連接的上下限數(shù)以及每個(gè)連接的最大使用次數(shù)、最大空閑時(shí)間等等。也可以通過(guò)其自身的管理機(jī)制來(lái)監(jiān)視數(shù)據(jù)庫(kù)連接的數(shù)量、使用情況等。

下面我來(lái)簡(jiǎn)單解釋一下,因?yàn)槊看蜶edis客戶(hù)端連接Redis服務(wù)端都需要一段時(shí)間,而處理各種操作的時(shí)間很多時(shí)候都很短,如果每次進(jìn)行各種操作時(shí)都需要重新連接Redis,那么就會(huì)浪費(fèi)大量時(shí)間。因此Redis引入連接池,連接池可以實(shí)現(xiàn)建立多個(gè)客戶(hù)端連接而不釋放,避免浪費(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代表無(wú)限
        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;i10;i++{
        go getConnFromPoolAndHappy(pool,i)
    }
    //保持主協(xié)程存活
    time.Sleep(3*time.Second)
​
}
​
func getConnFromPoolAndHappy(pool *redis.Pool, i int)  {
    //通過(guò)連接池獲得連接
    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ù)是無(wú)上限的。

MaxIdle: 20

表示連接池閑置連接數(shù)的上限。

IdleTimeout: time.Second * 100

該值表示如果連接池的的連接閑置超過(guò)該值就會(huì)關(guān)閉連接。如果該值為零,連接池中閑置的連接就不會(huì)關(guān)閉。應(yīng)用程序應(yīng)該設(shè)置這個(gè)限制超時(shí)時(shí)間不超過(guò)服務(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)。
開(kāi)辟一條并發(fā)協(xié)程執(zhí)行該函數(shù),因?yàn)閒or循環(huán)的范圍是0-9,所以并發(fā)數(shù)為10,表示同時(shí)有10個(gè)人去連接池取管道。

go getConnFromPoolAndHappy(pool,i)

下列代碼是用來(lái)保持主協(xié)程存活的。

time.Sleep(3*time.Second)

下面表示通過(guò)連接池獲得連接。也就是從池子拿一根管道。

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)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • go語(yǔ)言操作redis連接池的方法

標(biāo)簽:延邊 張掖 宜賓 新余 黑龍江 武漢 江西 嘉峪關(guān)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Go實(shí)現(xiàn)Redis連接池方法》,本文關(guān)鍵詞  實(shí)現(xiàn),Redis,連接,池,方法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Go實(shí)現(xiàn)Redis連接池方法》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于Go實(shí)現(xiàn)Redis連接池方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    涟水县| 邵阳县| 方城县| 邵东县| 商洛市| 东安县| 隆昌县| 河南省| 海安县| 房产| 清新县| 札达县| 康马县| 孝感市| 长兴县| 施秉县| 朝阳区| 汶上县| 开远市| 芒康县| 房山区| 郓城县| 金秀| 永宁县| 灌云县| 永顺县| 青冈县| 高安市| 江源县| 河南省| 西藏| 西丰县| 乾安县| 铁岭市| 巍山| 周口市| 天全县| 缙云县| 乌兰县| 奉贤区| 凤庆县|