Golang如何實(shí)現(xiàn)連接池的方法-創(chuàng)新互聯(lián)

Golang如何實(shí)現(xiàn)連接池的方法?這個(gè)問題可能是我們?nèi)粘W(xué)習(xí)或工作經(jīng)常見到的。希望通過這個(gè)問題能讓你收獲頗深。下面是小編給大家?guī)淼膮⒖純?nèi)容,讓我們一起來看看吧!

創(chuàng)新互聯(lián)建站網(wǎng)站建設(shè)提供從項(xiàng)目策劃、軟件開發(fā),軟件安全維護(hù)、網(wǎng)站優(yōu)化(SEO)、網(wǎng)站分析、效果評估等整套的建站服務(wù),主營業(yè)務(wù)為網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站設(shè)計(jì),成都app軟件開發(fā)公司以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。創(chuàng)新互聯(lián)建站深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

問題引入

作為一名Golang開發(fā)者,線上環(huán)境遇到過好幾次連接數(shù)暴增問題(mysql/redis/kafka等)。

糾其原因,Golang作為常駐進(jìn)程,請求第三方服務(wù)或者資源完畢后,需要手動關(guān)閉連接,否則連接會一直存在。而很多時(shí)候,開發(fā)者不一定記得關(guān)閉這個(gè)連接。

這樣是不是很麻煩?于是有了連接池。顧名思義,連接池就是管理連接的;我們從連接池獲取連接,請求完畢后再將連接還給連接池;連接池幫我們做了連接的建立、復(fù)用以及回收工作。

在設(shè)計(jì)與實(shí)現(xiàn)連接池時(shí),我們通常需要考慮以下幾個(gè)問題:

  • 連接池的連接數(shù)目是否有限制,大可以建立多少個(gè)連接?
  • 當(dāng)連接長時(shí)間沒有使用,需要回收該連接嗎?
  • 業(yè)務(wù)請求需要獲取連接時(shí),此時(shí)若連接池?zé)o空閑連接且無法新建連接,業(yè)務(wù)需要排隊(duì)等待嗎?
  • 排隊(duì)的話又存在另外的問題,隊(duì)列長度有無限制,排隊(duì)時(shí)間呢?

Golang連接池實(shí)現(xiàn)原理

我們以Golang HTTP連接池為例,分析連接池的實(shí)現(xiàn)原理。

結(jié)構(gòu)體Transport

Transport結(jié)構(gòu)定義如下:

type Transport struct {
  //操作空閑連接需要獲取鎖
  idleMu    sync.Mutex
  //空閑連接池,key為協(xié)議目標(biāo)地址等組合
  idleConn   map[connectMethodKey][]*persistConn // most recently used at end
  //等待空閑連接的隊(duì)列,基于切片實(shí)現(xiàn),隊(duì)列大小無限制
  idleConnWait map[connectMethodKey]wantConnQueue // waiting getConns
  
  //排隊(duì)等待建立連接需要獲取鎖
  connsPerHostMu  sync.Mutex
  //每個(gè)host建立的連接數(shù)
  connsPerHost   map[connectMethodKey]int
  //等待建立連接的隊(duì)列,同樣基于切片實(shí)現(xiàn),隊(duì)列大小無限制
  connsPerHostWait map[connectMethodKey]wantConnQueue // waiting getConns
  
  //大空閑連接數(shù)
  MaxIdleConns int
  //每個(gè)目標(biāo)host大空閑連接數(shù);默認(rèn)為2(注意默認(rèn)值)
  MaxIdleConnsPerHost int
  //每個(gè)host可建立的大連接數(shù)
  MaxConnsPerHost int
  //連接多少時(shí)間沒有使用則被關(guān)閉
  IdleConnTimeout time.Duration
  
  //禁用長連接,使用短連接
  DisableKeepAlives bool
}

新聞名稱:Golang如何實(shí)現(xiàn)連接池的方法-創(chuàng)新互聯(lián)
分享路徑:http://muchs.cn/article28/dpsgjp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站策劃、商城網(wǎng)站、品牌網(wǎng)站制作網(wǎng)站設(shè)計(jì)、虛擬主機(jī)、App設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管