Redis進(jìn)階-Redis對(duì)于過(guò)期鍵的三種清除策略
文章目錄
Pre
Redis Key的超時(shí)設(shè)置處理
被動(dòng)刪除
主動(dòng)刪除
當(dāng)前已用內(nèi)存超過(guò)maxmemory限定時(shí),觸發(fā)主動(dòng)清理策略
總結(jié)
Pre
Redis-17Redis內(nèi)存回收策略
Redis Key的超時(shí)設(shè)置處理
expire key seconds
1
單位是秒。返回1成功,0表示key已經(jīng)設(shè)置過(guò)過(guò)期時(shí)間或者不存在。 如果想消除超時(shí)則使用persist key。如果希望采用絕對(duì)超時(shí),則使用expireat命令。
ttl key
1
返回設(shè)置過(guò)過(guò)期時(shí)間的key的剩余過(guò)期秒數(shù) -1表示沒有設(shè)置過(guò)過(guò)期時(shí)間,對(duì)于不存在的key,返回-2。
pexpire key 毫秒數(shù)
1
設(shè)置生命周期。
pttl key
1
以毫秒返回生命周期。
被動(dòng)刪除
當(dāng)讀/寫一個(gè)已經(jīng)過(guò)期的key時(shí),會(huì)觸發(fā)惰性刪除策略,直接刪除掉這個(gè)過(guò)期key.
舉個(gè)例子, set 一個(gè) 過(guò)期時(shí)間為 600s的 key , 當(dāng) 到了 600s后,redis 并不會(huì)執(zhí)行刪除, 為了性能,redis 會(huì)在你下次訪問(wèn)的時(shí)候 去刪除 。
這樣的話,我如果永遠(yuǎn)不訪問(wèn),那不歇菜了么? 不要著急,Redis還有主動(dòng)刪除 。
主動(dòng)刪除
由于惰性刪除策略無(wú)法保證冷數(shù)據(jù)被及時(shí)刪掉,所以Redis會(huì)定期主動(dòng)淘汰一批已過(guò)期的key。
說(shuō)白了,這就是定時(shí)任務(wù)干的活,防止有些key 一直占用內(nèi)存。
當(dāng)REDIS運(yùn)行在主從模式時(shí),只有主結(jié)點(diǎn)才會(huì)執(zhí)行被動(dòng)和主動(dòng)這兩種過(guò)期刪除策略,然后把刪除操作”del key”同步到從結(jié)點(diǎn).
當(dāng)前已用內(nèi)存超過(guò)maxmemory限定時(shí),觸發(fā)主動(dòng)清理策略
第三種策略的情況: 當(dāng)前已用內(nèi)存超過(guò)maxmemory限定時(shí),會(huì)觸發(fā)主動(dòng)清理策略.
我們需要根據(jù)自身業(yè)務(wù)類型,選好maxmemory-policy(最大內(nèi)存淘汰策略),設(shè)置好過(guò)期時(shí)間。如果不設(shè)置最大內(nèi)存,當(dāng) Redis 內(nèi)存超出物理內(nèi)存限制時(shí),內(nèi)存的數(shù)據(jù)會(huì)開始和磁盤產(chǎn)生頻繁的交換 (swap)會(huì)讓 Redis 的性能急劇下降。
默認(rèn)策略是volatile-lru,即超過(guò)最大內(nèi)存后,在過(guò)期鍵中使用lru算法進(jìn)行key的剔除,保證不過(guò)期數(shù)據(jù)不被刪除,但是可能會(huì)出現(xiàn)OOM問(wèn)題。
其他策略如下:
allkeys-lru:根據(jù)LRU算法刪除鍵,不管數(shù)據(jù)有沒有設(shè)置超時(shí)屬性,直到騰出足夠空間 為止
allkeys-random:隨機(jī)刪除所有鍵,直到騰出足夠空間為止。
allkeys-random:隨機(jī)刪除所有鍵,直到騰出足夠空間為止。
volatile-ttl:根據(jù)鍵值對(duì)象的ttl屬性,刪除最近將要過(guò)期數(shù)據(jù)。如果沒有,回退到noeviction策略。
noeviction:不會(huì)剔除任何數(shù)據(jù),拒絕所有寫入操作并返回客戶端錯(cuò)誤信息"(error)。OOM command not allowed when used memory",此時(shí)Redis只響應(yīng)讀操作
記?。?volatile 開頭的策略,只清理過(guò)期的key , 而all開頭的策略則不管你過(guò)不過(guò)期,都會(huì)清理。
總結(jié)
當(dāng)client主動(dòng)訪問(wèn)key會(huì)先對(duì)key進(jìn)行超時(shí)判斷,過(guò)時(shí)的key會(huì)立刻刪除。
從節(jié)點(diǎn)不會(huì)過(guò)期掃描,從節(jié)點(diǎn)對(duì)過(guò)期的處理是被動(dòng)的。 在主從復(fù)制環(huán)境中,由于上述原因存在已經(jīng)過(guò)期但是沒有刪除的key,在主snapshot時(shí)并不包含這些key,因此在slave環(huán)境中我們往往看到dbsize較master是更小的。
如果clien永遠(yuǎn)都不再get那條key呢?
redis會(huì)在Master的后臺(tái),每秒10次的執(zhí)行如下操作:
隨機(jī)選取100個(gè)key校驗(yàn)是否過(guò)期,如果有25個(gè)以上的key過(guò)期了,立刻額外隨機(jī)選取下100個(gè)key(不計(jì)算在10次之內(nèi))??梢姡绻^(guò)期的key不多,它最多每秒回收200條左右,如果有超過(guò)25%的key過(guò)期了,它就會(huì)做得更多。
Redis
版權(quán)聲明:本文內(nèi)容由網(wǎng)絡(luò)用戶投稿,版權(quán)歸原作者所有,本站不擁有其著作權(quán),亦不承擔(dān)相應(yīng)法律責(zé)任。如果您發(fā)現(xiàn)本站中有涉嫌抄襲或描述失實(shí)的內(nèi)容,請(qǐng)聯(lián)系我們jiasou666@gmail.com 處理,核實(shí)后本網(wǎng)站將在24小時(shí)內(nèi)刪除侵權(quán)內(nèi)容。