无码中文AV有码中文AV,免费观看的a级毛片的网站,国产无吗一区二区三区在线欢,好男人资源免费播放在线观看

當前時訊:Redis高可用高性能緩存的應用系列03 - 緩存過期淘汰策略LRU、LFU

發(fā)布時間:2023-04-14 02:24:52
來源:騰訊云

概述

Redis高可用高性能緩存的應用系列的第3篇,主要介紹Redis緩存過期淘汰策略的知識點。

Redis過期鍵刪除策略

Redis設置key時,都會設置一個過期時間,那么當過期時間到了都是怎么處理的?

Redis同時使用了惰性過期和定期過期兩種方式的緩存淘汰策略。


(資料圖)

惰性過期:只有當這個key被訪問時,才會判斷是否過期,過期則要清理掉,他可以節(jié)省CPU的資源,但是會浪費內(nèi)存的資源,會出現(xiàn)大量過的Key沒有被訪問過,從而不會被清除,導致內(nèi)容占用越來越大。定期過期:每隔一段時間,掃描一定數(shù)量的設置了過期時間的key,假如過期了則進行刪除操作。

定期過期的執(zhí)行過程

Redis默認每秒進行10次過期掃描:

1.從過期字典中隨機選擇20個key

2.刪除這20個key中已過期的

3.如果超過25%的key過期,則重復第一步

同時,為了保證業(yè)務不受影響,Redis還設置了掃描的時間上限,默認不會超過25ms

內(nèi)存淘汰策略

1.假如內(nèi)存不足時,Redis會根據(jù)設置的淘汰策略,刪除一些不常用的數(shù)據(jù),保證Redis的正常使用,所有的前提都是加入鍵的時候如果超過Redis內(nèi)存設定的限制后,Redis采用的服務。

1.noeviction: 不會在寫入,寫入會報錯。

2.allkeys-lru:首先通過LRU算法驅(qū)逐最久沒有使用的鍵

3.volatile-lru:首先從設置了過期時間的鍵集合中驅(qū)逐沒有最久使用的鍵

4.allkeys-random:從所有過期字典中的key隨機刪除

5.volatile-random:從過期鍵的集合中隨機驅(qū)逐

6.volatile-ttl:從配置了過期時間的鍵中,驅(qū)逐馬上就要過期的鍵

7.volatile-lfu:從配置了過期時間的鍵中驅(qū)逐使用頻率最少得鍵

8.allkeys-lfu:從所有鍵中使用頻率最少的鍵

LRU

根據(jù)最近被使用的時間,距離當前最遠的數(shù)據(jù)優(yōu)化被淘汰,當有新增key 或者是被訪問時,元素會被追加在隊尾,需要淘汰時從頭部開始淘汰,這個是LRU的思想。

在Redis redisObject 中,維護了一個24位的時鐘(有點類似于Cpu的頻率),可以簡單理解為Cpu對內(nèi)存使用的時間戳,每個Key對應的也維護了同樣24位的時間戳。

比如現(xiàn)在要進行LRU,首先拿到當前系統(tǒng)的時間鐘,和Redis redisObject 內(nèi)存的LRU時間鐘對差值計算,差最大的進行淘汰,這里需要注意的是,全局時鐘只有24位,按秒計算的話,最多可以存儲194天,所以可能出現(xiàn)key時鐘大于全局時鐘的情況,但是Redis的LRU不會對全局的時鐘進行比對,他會從設置了過期時間的key中進行比對。

struct redisObject {    unsigned lru:LRU_BITS; /* LRU time (relative to global lru_clock) or                            * LFU data (least significant 8 bits frequency                            * and most significant 16 bits access time). */};

LFU

LRU只考慮了使用的時間,但是沒有考慮Key使用的次數(shù),Redis4.0 以后,新增了LFU的淘汰策略,根據(jù)使用時間和次數(shù)最為淘汰的權重。

LFU把之前LRU的24bit拆分成兩部分,16bit的時間鐘和8it的訪問頻率,8bit比較小,在源碼的evict文件中給出了數(shù)據(jù)。

uint8_t LFULogIncr(uint8_t counter) {    if (counter == 255) return 255;    double r = (double)rand()/RAND_MAX;    double baseval = counter - LFU_INIT_VAL;    if (baseval < 0) baseval = 0;    double p = 1.0/(baseval*server.lfu_log_factor+1);    if (r < p) counter++;    return counter;}

標簽:

AD
更多相關文章