亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > golang中cache組件的使用及groupcache源碼解析

golang中cache組件的使用及groupcache源碼解析

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

groupcache 簡介

在軟件系統中使用緩存,可以降低系統響應時間,提高用戶體驗,降低某些系統模塊的壓力.
groupcache是一款開源的緩存組件.與memcache與redis不同的時,groupcache不需要單獨的部署,可以作為你程序的一個庫來使用. 這樣方便我們開發的程序部署.

本篇主要解析groupcache源碼中的關鍵部分, lru的定義以及如何做到同一個key只加載一次。

緩存填充以及加載抑制的實現

上篇有提到load函數的實現, 緩存填充的邏輯也體現在這里。
groupcache盡量避免從源中獲取數據,當本地數據缺失時會先從peer中獲取,peer中命中則直接填充到本地,未命中才會從源中加載,這正是緩存填充的實現邏輯。
而加載抑制,避免重復加載的功能是依靠 singleflight包實現的。
這個包中主要有兩個結構體:

call用來存放獲取結果(val)和錯誤(err), 每個key對應一個call實例。wg用來控制請求的等待。

type call struct {
	wg  sync.WaitGroup
	val interface{}
	err error
}

Group用來存放所有的call,記錄所有的請求。

type Group struct {
	mu sync.Mutex       // protects m
	m  map[string]*call // lazily initialized
}

Group.Do是功能的實現。
當接到一個請求時, 會首先加鎖, 并初始化用來記錄請求的mapmap的鍵為請求的key, 值為call

g.mu.Lock()
if g.m == nil {
	g.m = make(map[string]*call)
}

如果當前的key已經在請求加載的過程中,那么解除上一步定義的沖突鎖,并等待已經存在的加載請求結束后返回。

if c, ok := g.m[key]; ok {
	g.mu.Unlock()
	c.wg.Wait()
	return c.val, c.err
}

如果當前的key沒有已經存在的加載過程,那么創建一個call實例, 加入到map記錄中,并向call.wg中加入一個記錄,以阻塞其他請求,解除上一步定義的沖突鎖。

c := new(call)
c.wg.Add(1)
g.m[key] = c
g.mu.Unlock()

調用傳入的函數(作者并沒有將這個功能局限于數據獲取,通過傳入的func可以實現不同功能的控制),將結果賦值給call,獲取完成后wg.done結束阻塞。

c.val, c.err = fn()
c.wg.Done()

然后刪除map記錄

g.mu.Lock()
delete(g.m, key)
g.mu.Unlock()

這個功能的實現主要是依靠sync.WaitGroup的阻塞實現, 這里也是對初學者最難理解的地方。
可以想象一個場景:
大學寢室中,你和你的室友都要到食堂買午飯,你對室友說:“你自己去就行,給我帶一份”。然后你就在宿舍中等待舍友回來。
在這個場景中,你和室友就是請求,你在等待就是阻塞

cache(lru)

上篇提到的主緩存和熱緩存均是依靠cache實現。
cache的實現依靠雙向鏈表。
MaxEntries 最大的存儲量
OnEvicted當發生驅逐時(即到達MaxEntries)執行的操作
ll雙向鏈表本體
cache key對應鏈表中的元素

type Cache struct {
	// MaxEntries is the maximum number of cache entries before
	// an item is evicted. Zero means no limit.
	MaxEntries int

	// OnEvicted optionally specifies a callback function to be
	// executed when an entry is purged from the cache.
	OnEvicted func(key Key, value interface{})

	ll    *list.List
	cache map[interface{}]*list.Element
}

添加時會先進行初始化map,如果key已存在,那么會將keyindex提到首位(這里的鏈表不存在index,僅為方便理解),并更新其value。
如果不存在則直接插入到首位。
如果插入后的長度超過限制, 會執行清理操作

func (c *Cache) Add(key Key, value interface{}) {
	if c.cache == nil {
		c.cache = make(map[interface{}]*list.Element)
		c.ll = list.New()
	}
	if ee, ok := c.cache[key]; ok {
		c.ll.MoveToFront(ee)
		ee.Value.(*entry).value = value
		return
	}
	ele := c.ll.PushFront(entry{key, value})
	c.cache[key] = ele
	if c.MaxEntries != 0  c.ll.Len() > c.MaxEntries {
		c.RemoveOldest()
	}
}

清理時會刪除尾部元素, 這里就解釋了為什么每次操作時會把元素提到首位。

func (c *Cache) RemoveOldest() {
	if c.cache == nil {
		return
	}
	ele := c.ll.Back()
	if ele != nil {
		c.removeElement(ele)
	}
}

以上就是golang中cache組件的使用之groupcache的詳細內容,更多關于go groupcache用法的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • 詳解一種用django_cache實現分布式鎖的方式
  • Django中的CACHE_BACKEND參數和站點級Cache設置
  • 淺析Python的Django框架中的Memcached
  • go語言實現的memcache協議服務的方法
  • python連接MySQL、MongoDB、Redis、memcache等數據庫的方法

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

巨人網絡通訊聲明:本文標題《golang中cache組件的使用及groupcache源碼解析》,本文關鍵詞  golang,中,cache,組件,的,使用,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang中cache組件的使用及groupcache源碼解析》相關的同類信息!
  • 本頁收集關于golang中cache組件的使用及groupcache源碼解析的相關信息資訊供網民參考!
  • 推薦文章
    好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日韩在线观看免费| 成人a级高清视频在线观看| 欧美另类videosbestsex高清| 欧美激情在线精品video| 精品视频免费看| 国产一区二区精品| 国产高清在线精品一区a| 欧美另类videosbestsex高清| 欧美激情一区二区三区中文字幕| 免费国产在线视频| 999精品视频在线| 亚洲 男人 天堂| 日韩专区亚洲综合久久| 国产成人精品综合在线| 亚洲 男人 天堂| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产视频一区在线| 国产高清在线精品一区a| 国产欧美精品| 97视频免费在线| 欧美日本韩国| 夜夜操网| 国产高清在线精品一区a| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 九九九网站| 日韩字幕在线| 国产视频一区在线| 黄视频网站免费看| 日韩在线观看视频黄| 99久久精品国产高清一区二区 | 999精品在线| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 91麻豆精品国产自产在线观看一区 | 99色视频在线观看| 91麻豆国产| 国产麻豆精品| 精品久久久久久中文字幕2017| 日本在线www| 欧美一区二区三区在线观看| 日本伦理片网站| 国产欧美精品| 91麻豆tv| 尤物视频网站在线| 国产精品1024永久免费视频| 国产美女在线观看| 韩国毛片| 国产一区二区精品尤物| 四虎影视精品永久免费网站| 日韩中文字幕一区| 青青青草视频在线观看| 欧美激情一区二区三区在线| 亚洲女人国产香蕉久久精品| 亚洲wwwwww| 国产成人啪精品| 日韩在线观看网站| 四虎影视久久久免费| 日韩专区亚洲综合久久| 日韩中文字幕在线亚洲一区| 欧美激情在线精品video| 中文字幕97| 欧美a免费| 成人免费高清视频| 午夜精品国产自在现线拍| 可以免费看毛片的网站| 成人免费网站久久久| 国产不卡福利| 人人干人人插| 日韩中文字幕在线播放| 99热精品在线| 精品视频在线观看视频免费视频| 午夜精品国产自在现线拍| 国产成a人片在线观看视频| 亚洲精品影院久久久久久| 久久国产影院| 国产精品1024永久免费视频| 精品久久久久久影院免费| 中文字幕97| 精品视频一区二区| 日本免费看视频| 四虎影视精品永久免费网站| 日韩一级精品视频在线观看| 欧美爱爱动态| 成人免费一级毛片在线播放视频| 国产一区二区精品尤物| 国产亚洲精品aaa大片| 欧美激情一区二区三区中文字幕| 欧美一级视频免费| 久久成人性色生活片| 精品视频在线看| 欧美大片aaaa一级毛片| 精品视频一区二区| 成人免费一级毛片在线播放视频| 亚洲精品永久一区| 午夜激情视频在线播放| 午夜欧美成人久久久久久| 国产a视频| 久久国产一久久高清| 国产91视频网| 一本高清在线| 亚洲爆爽| 国产极品白嫩美女在线观看看| 成人影院久久久久久影院| 成人a级高清视频在线观看| 在线观看导航| 精品视频在线观看视频免费视频| 日韩一级精品视频在线观看| 91麻豆国产| 91麻豆国产| 久久成人性色生活片| 精品视频在线观看视频免费视频| 亚洲第一页乱| 青青青草视频在线观看| 国产不卡在线观看视频| 日本伦理片网站| 国产精品免费久久| 日韩字幕在线| 国产视频一区在线| 国产激情一区二区三区| 久草免费在线观看| 午夜欧美成人久久久久久| 亚洲精品永久一区| 国产91素人搭讪系列天堂| 你懂的日韩| 午夜欧美成人久久久久久| 日韩中文字幕一区| 超级乱淫黄漫画免费| 国产亚洲精品成人a在线| 精品视频免费看| 国产91素人搭讪系列天堂| 一级毛片视频在线观看| 免费国产在线观看| 91麻豆精品国产自产在线| 国产伦久视频免费观看 视频| 精品国产三级a| 可以免费看污视频的网站| 日韩av东京社区男人的天堂| 香蕉视频亚洲一级| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日韩专区亚洲综合久久| 午夜欧美福利| 欧美一区二区三区在线观看| 你懂的日韩| 久久国产精品自线拍免费| 香蕉视频亚洲一级| 亚洲第一色在线| 日韩免费在线| 国产精品自拍一区| 可以免费看污视频的网站| 国产精品1024永久免费视频| 99久久精品国产片| 91麻豆精品国产自产在线观看一区 | 国产一区二区福利久久| 国产成人精品综合在线| 沈樵在线观看福利| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 日本免费看视频| 国产成人女人在线视频观看| 亚洲天堂在线播放| 日韩中文字幕在线播放| 99色视频在线观看| 九九国产| 精品视频在线观看视频免费视频| 欧美一级视频免费| 日韩男人天堂| 国产麻豆精品免费视频| 国产网站在线| 午夜激情视频在线播放| 国产美女在线观看| 国产视频网站在线观看| 久久99青青久久99久久| 成人免费网站久久久| 中文字幕一区二区三区精彩视频| 精品国产香蕉在线播出| 日本乱中文字幕系列| 国产成人精品综合在线| 精品国产香蕉在线播出| 精品国产三级a| 青青久久精品| 欧美另类videosbestsex高清| 国产伦久视频免费观看 视频| 精品在线免费播放| 国产激情一区二区三区| 日韩avdvd| 国产亚洲免费观看| 二级特黄绝大片免费视频大片| 国产亚洲精品成人a在线| 免费一级片在线| 欧美激情一区二区三区在线| 久久久成人网| 久久精品大片| 999精品视频在线| 免费一级片在线| 国产网站免费视频| 高清一级淫片a级中文字幕 | 国产综合成人观看在线| 久草免费在线观看| 欧美大片一区| 国产成人啪精品| 日日夜夜婷婷|