好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Go實現Redis連接池方法

Go實現Redis連接池方法

熱門標簽:開通400電話申請流程 上海企業外呼系統排名 武漢百應人工智能電銷機器人 百度地圖標注位置網站 如何利用高德地圖標注家 智能語音電銷的機器人 揚州電銷外呼系統軟件 電腦外呼系統輻射大嗎 400手機電話免費辦理

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

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

連接池基本的思想是在系統初始化的時候,將數據庫連接作為對象存儲在內存中,當用戶需要訪問數據庫時,并非建立一個新的連接,而是從連接池中取出一個已建立的空閑連接對象。使用完畢后,用戶也并非將連接關閉,而是將連接放回連接池中,以供下一個請求訪問使用。而連接的建立、斷開都由連接池自身來管理。同時,還可以通過設置連接池的參數來控制連接池中的初始連接數、連接的上下限數以及每個連接的最大使用次數、最大空閑時間等等。也可以通過其自身的管理機制來監視數據庫連接的數量、使用情況等。

下面我來簡單解釋一下,因為每次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;i10;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連接池內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

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

標簽:延邊 張掖 宜賓 新余 黑龍江 武漢 江西 嘉峪關

巨人網絡通訊聲明:本文標題《Go實現Redis連接池方法》,本文關鍵詞  實現,Redis,連接,池,方法,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Go實現Redis連接池方法》相關的同類信息!
  • 本頁收集關于Go實現Redis連接池方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 波多野结衣一级片| 久久亚洲欧美日韩精品专区 | 又亲又揉摸下面视频免费看| 偷拍亚洲色图| 国产?高潮?白浆?喷水| 色婷婷久久综合久色综合| 日本黄色视屏| asian极品裸体女pics| 手机在线观看一级午夜片| 好紧好爽再浪一点女女交换| 亚洲三级电影网| 91黑料精品国产| 伊人网免费视频| 成人无码区免费A片久久鸭软件| 男女操网站| a在线视频免费观看| 西西大胆私人ti艺体| 午夜爽爽爽男女免费观看| 女总裁雪臀轻抬迎合巨龙| 亚洲欧美电影在线一区二区| 亚洲男人的天堂视频| 97高清视频在线观看免费| 美女被男人桶爽| 久久夜色精品亚洲AV三区| 国产精品48页| bl啊太深了别停双性| 69精品人人槡人妻人人玩 | 欧美日韩一区二区不卡| 在线a亚洲老鸭窝天堂新地址| 日韩爽爽影院| 91精品国产一二三区网站入口 | 亚洲另类激情综合偷自拍图 | 久久久综合视频| 欧美三级无码大尺度在线热辣宝贝 | 欧美老熟好丰满大BWW| 精产国品一二三产区入口公司| 一级黄色欧美| 性刺激视频在线播放免费| 日韩精品――色哟哟| BGMBGMBGM老太太毛多多吧 | 老鸭窝国产AV 在线|