Redis進(jìn)階-Redis對(duì)于過(guò)期鍵的三種清除策略

      網(wǎng)友投稿 784 2022-05-29

      文章目錄

      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).

      Redis進(jìn)階-Redis對(duì)于過(guò)期鍵的三種清除策略

      當(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)容。

      上一篇:DevOps進(jìn)階(十六)linux下的find文件查找命令與grep文件內(nèi)容查找命令
      下一篇:數(shù)據(jù)庫(kù)復(fù)制的類別
      相關(guān)文章
      亚洲精品无码成人片久久不卡| 亚洲综合色区中文字幕| 亚洲午夜国产精品| 亚洲一区二区三区偷拍女厕 | 无码专区一va亚洲v专区在线| 精品国产成人亚洲午夜福利| 亚洲av永久无码精品三区在线4 | 91麻豆国产自产在线观看亚洲 | 亚洲一区二区久久| 亚洲色欲色欲www| 久久久国产亚洲精品| 亚洲乱码中文字幕在线| 亚洲AV日韩AV一区二区三曲| WWW亚洲色大成网络.COM| 亚洲人成网站看在线播放| 亚洲成人黄色在线观看| jlzzjlzz亚洲jzjzjz| 亚洲熟妇无码八V在线播放 | 亚洲国产精品无码一线岛国 | 亚洲成a∧人片在线观看无码| 亚洲精品无码久久久久牙蜜区| 亚洲精华国产精华精华液好用 | 亚洲精品成人av在线| 亚洲白色白色在线播放| 亚洲一级片在线播放| 亚洲宅男天堂a在线| 亚洲人成77777在线播放网站不卡| 亚洲熟伦熟女专区hd高清| 亚洲AV香蕉一区区二区三区| 国产亚洲精品欧洲在线观看| 国产精品亚洲mnbav网站| 人人狠狠综合久久亚洲婷婷| 亚洲视频.com| 亚洲AV无码乱码麻豆精品国产| 四虎亚洲精品高清在线观看| 日本中文一区二区三区亚洲| 亚洲中文字幕无码久久精品1| 亚洲av色影在线| 亚洲国产超清无码专区| 亚洲精品无码日韩国产不卡av| 亚洲国产成人影院播放|