濮阳杆衣贸易有限公司

主頁 > 知識庫 > 如何高效使用Redis作為LRU緩存

如何高效使用Redis作為LRU緩存

熱門標簽:高碑店市地圖標注app b2b外呼系統(tǒng) 四川穩(wěn)定外呼系統(tǒng)軟件 南京手機外呼系統(tǒng)廠家 地圖標注工廠入駐 一個地圖標注多少錢 臺灣電銷 廊坊外呼系統(tǒng)在哪買 400電話辦理的口碑

當用Redis作為一個LRU存儲時,有些時候是比較方便的,在你增添新的數(shù)據(jù)時會自動驅(qū)逐舊的數(shù)據(jù)。這種行為在開發(fā)者論壇是非常有名的,因為這是流行的memcached系統(tǒng)的默認行為。

LRU實際上只是支持驅(qū)逐的方式之一。這頁包含更多一般的Redis maxmemory指令的話題用于限制內(nèi)存使用到一個定額,同時它也深入的涵蓋了Redis所使用的LRU算法,實際上是精確LRU的近似值。

一、Maxmemory設(shè)置指令

Maxmemory設(shè)置指令用于配置Redis的數(shù)據(jù)集使用指定量的內(nèi)存??梢杂胷edis conf.file設(shè)置指令,或者可以在稍晚的時候在運行時間用config set命令。

例如,為了設(shè)置內(nèi)存局限于100百萬字節(jié),下列指令可在redis.conf file內(nèi)使用。設(shè)置maxmemory到零使得沒有內(nèi)存限制。這是64位系統(tǒng)的默認行為,而32位系統(tǒng)使用3GB內(nèi)隱記憶極限。

maxmemory 100mb

當達到指定量的內(nèi)存后,就可以選擇不同的行為,稱為策略。Redis可以返回錯誤的指令,導(dǎo)致使用更多的內(nèi)存,或者為了每次增加新的數(shù)據(jù)后返回指定的內(nèi)存,它可以驅(qū)逐一些舊的數(shù)據(jù)。

二、驅(qū)逐策略

當?shù)竭_maxmemory極限時,使用maxmemory-策略配置指令來執(zhí)行具體的Redis動作。

以下策略可以使用:

1、noeviction:達到內(nèi)存限額后返回錯誤,客戶嘗試可以導(dǎo)致更多內(nèi)存使用的命令(大部分寫命令,但DEL和一些例外)

2、allkeys-lru:為了給新增加的數(shù)據(jù)騰出空間,驅(qū)逐鍵先試圖移除一部分最近使用較少的(LRC)。

3、volatile-lru:為了給新增加的數(shù)據(jù)騰出空間,驅(qū)逐鍵先試圖移除一部分最近使用較少的(LRC),但只限于過期設(shè)置鍵。

4、allkeys-random: 為了給新增加的數(shù)據(jù)騰出空間,驅(qū)逐任意鍵。

5、volatile-random: 為了給新增加的數(shù)據(jù)騰出空間,驅(qū)逐任意鍵,但只限于有過期設(shè)置的驅(qū)逐鍵。

6、volatile-ttl: 為了給新增加的數(shù)據(jù)騰出空間,驅(qū)逐鍵只有秘鑰過期設(shè)置,并且首先嘗試縮短存活時間的驅(qū)逐鍵。

如果沒有秘鑰去驅(qū)逐匹配先決條件,策略volatile-lru, volatile-random 和volatile-ttl行為很像noeviction。

那么根據(jù)你應(yīng)用的訪問模式選擇正確的驅(qū)逐策略是很重要的。然而在應(yīng)用運行時你可以在運行時間重新設(shè)置策略,并且監(jiān)控緩存缺失的數(shù)量并為了調(diào)整你的設(shè)置點擊Redis信息輸出。

三、近似LRU算法

Redis的LRU算法不是準確的實現(xiàn)。也就是說Redis沒有為逐出選擇 最好的候選人 ,也就是沒有選擇過去最后被訪問離現(xiàn)在最久的。反而 是去執(zhí)行一個 近似LRU的算法,通過抽樣少量的key,并且逐出抽樣中最后被訪問離現(xiàn)在最久的key(最老的訪問時間)。

在Redis 3.0(目前的測試版),算法被改進了,使用了一個逐出最佳候選池。改進了算法的性能,使它更加近似真正LRU算法。

算法中,關(guān)于逐出檢測的樣品數(shù)量,你可以自己去調(diào)整。配置參數(shù)是:

maxmemory-samples 5

Redis沒有使用真正實現(xiàn)LRU算是的原因是,因為消耗更多的內(nèi)存。然而對于使用Redis的應(yīng)用來說,事實上是等價的。下面是Redis的LRU算法和真正LRU算法的比較:

給出配置數(shù)量的key生成上面的圖表。key從第一行到最后一行被訪問,那么第一個key是LRU算法中最好的逐出候選者。之后有50%的key被添加,那么一半的舊key被逐出。

在上圖中你可以看見3個明顯的區(qū)別:

1、淺灰色帶是被逐出的對象。

2、灰色帶是沒有被逐出的對象。

3、綠色帶是被添加的對象。

LRU理論實現(xiàn)是在所有的舊key中前一半被逐出。Redis使用的是近似過期的key被逐出。

如你所見,3.0的工作比2.8更好,然而在2.8版本中,大多數(shù)最新訪問對象的仍然保留。在3.0使用樣品為10 時,性能非常接近理論上的LRU算法。

注意:LRU僅僅是一個預(yù)測模式,給出的key很可能在未來被訪問。此外,如果你的數(shù)據(jù)訪問模式類似于冪律(線性的),大多數(shù)key都可能被訪問那么這個LRU算法的處理就是非常好的。

在實戰(zhàn)中 ,我們發(fā)現(xiàn)使用冪律(線性的)的訪問模式,在真正的LRU算法和Redis的LRU算法之間差異很小或者不存在差異。

你可以提升樣品大小配置到10,它將接近真正的LRU算法,并且有不同錯過率,但是要消耗更多的CPU。

在調(diào)試時使用不同的樣品大小去調(diào)試非常簡單,使用命令CONFIG SET maxmemory-samples 實現(xiàn)。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Redis中LRU淘汰策略的深入分析
  • Redis的LRU機制介紹
  • Redis緩存常用4種策略原理詳解
  • 手動實現(xiàn)Redis的LRU緩存機制示例詳解

標簽:畢節(jié) 泰州 南寧 河源 甘南 定州 拉薩 伊春

巨人網(wǎng)絡(luò)通訊聲明:本文標題《如何高效使用Redis作為LRU緩存》,本文關(guān)鍵詞  如何,高效,使用,Redis,作為,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《如何高效使用Redis作為LRU緩存》相關(guān)的同類信息!
  • 本頁收集關(guān)于如何高效使用Redis作為LRU緩存的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    平湖市| 民乐县| 修文县| 黑水县| 绥德县| 青龙| 洪泽县| 专栏| 称多县| 永川市| 固原市| 新营市| 甘洛县| 江源县| 喀喇沁旗| 浠水县| 峨边| 西峡县| 多伦县| 新郑市| 石泉县| 平顺县| 东山县| 平南县| 龙陵县| 张家界市| 台湾省| 隆德县| 沙雅县| 夏河县| 荃湾区| 高要市| 寿光市| 高碑店市| 通城县| 休宁县| 瑞安市| 阿拉善左旗| 怀柔区| 襄樊市| 贡山|