您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“Redis對(duì)于過(guò)期鍵的清除策略有哪些”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“Redis對(duì)于過(guò)期鍵的清除策略有哪些”吧!
Redis-17Redis內(nèi)存回收策略
expire key seconds
單位是秒。返回1成功,0表示key已經(jīng)設(shè)置過(guò)過(guò)期時(shí)間或者不存在。 如果想消除超時(shí)則使用persist key。如果希望采用絕對(duì)超時(shí),則使用expireat命令。
ttl key
返回設(shè)置過(guò)過(guò)期時(shí)間的key的剩余過(guò)期秒數(shù) -1表示沒(méi)有設(shè)置過(guò)過(guò)期時(shí)間,對(duì)于不存在的key,返回-2。
pexpire key 毫秒數(shù)
設(shè)置生命周期。
pttl key
以毫秒返回生命周期。
當(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)刪除 。
由于惰性刪除策略無(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í),會(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ì)開(kāi)始和磁盤產(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ù)有沒(méi)有設(shè)置超時(shí)屬性,直到騰出足夠空間 為止
allkeys-random:隨機(jī)刪除所有鍵,直到騰出足夠空間為止。
allkeys-random:隨機(jī)刪除所有鍵,直到騰出足夠空間為止。
volatile-ttl:根據(jù)鍵值對(duì)象的ttl屬性,刪除最近將要過(guò)期數(shù)據(jù)。如果沒(méi)有,回退到noeviction策略。
noeviction:不會(huì)剔除任何數(shù)據(jù),拒絕所有寫入操作并返回客戶端錯(cuò)誤信息"(error)。OOM command not allowed when used memory",此時(shí)Redis只響應(yīng)讀操作
記?。?volatile 開(kāi)頭的策略,只清理過(guò)期的key , 而all開(kāi)頭的策略則不管你過(guò)不過(guò)期,都會(huì)清理。
當(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ò)期但是沒(méi)有刪除的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))??梢?jiàn),如果過(guò)期的key不多,它最多每秒回收200條左右,如果有超過(guò)25%的key過(guò)期了,它就會(huì)做得更多。
到此,相信大家對(duì)“Redis對(duì)于過(guò)期鍵的清除策略有哪些”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。