日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

Redis进阶-Redis对于过期键的三种清除策略

發布時間:2025/3/21 数据库 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Redis进阶-Redis对于过期键的三种清除策略 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • Pre
  • Redis Key的超時設置處理
  • 被動刪除
  • 主動刪除
  • 當前已用內存超過maxmemory限定時,觸發主動清理策略
  • 總結


Pre

Redis-17Redis內存回收策略


Redis Key的超時設置處理

expire key seconds

單位是秒。返回1成功,0表示key已經設置過過期時間或者不存在。 如果想消除超時則使用persist key。如果希望采用絕對超時,則使用expireat命令。

ttl key

返回設置過過期時間的key的剩余過期秒數 -1表示沒有設置過過期時間,對于不存在的key,返回-2。

pexpire key 毫秒數

設置生命周期。

pttl key

以毫秒返回生命周期。


被動刪除

當讀/寫一個已經過期的key時,會觸發惰性刪除策略,直接刪除掉這個過期key.

舉個例子, set 一個 過期時間為 600s的 key , 當 到了 600s后,redis 并不會執行刪除, 為了性能,redis 會在你下次訪問的時候 去刪除 。

這樣的話,我如果永遠不訪問,那不歇菜了么? 不要著急,Redis還有主動刪除 。


主動刪除

由于惰性刪除策略無法保證冷數據被及時刪掉,所以Redis會定期主動淘汰一批已過期的key。

說白了,這就是定時任務干的活,防止有些key 一直占用內存。

當REDIS運行在主從模式時,只有主結點才會執行被動和主動這兩種過期刪除策略,然后把刪除操作”del key”同步到從結點.


當前已用內存超過maxmemory限定時,觸發主動清理策略

第三種策略的情況: 當前已用內存超過maxmemory限定時,會觸發主動清理策略.

我們需要根據自身業務類型,選好maxmemory-policy(最大內存淘汰策略),設置好過期時間。如果不設置最大內存,當 Redis 內存超出物理內存限制時,內存的數據會開始和磁盤產生頻繁的交換 (swap)會讓 Redis 的性能急劇下降。

默認策略是volatile-lru,即超過最大內存后,在過期鍵中使用lru算法進行key的剔除,保證不過期數據不被刪除,但是可能會出現OOM問題

其他策略如下:

  • allkeys-lru:根據LRU算法刪除鍵,不管數據有沒有設置超時屬性,直到騰出足夠空間 為止
  • allkeys-random:隨機刪除所有鍵,直到騰出足夠空間為止。
  • allkeys-random:隨機刪除所有鍵,直到騰出足夠空間為止。
  • volatile-ttl:根據鍵值對象的ttl屬性,刪除最近將要過期數據。如果沒有,回退到noeviction策略。
  • noeviction:不會剔除任何數據,拒絕所有寫入操作并返回客戶端錯誤信息"(error)。OOM command not allowed when used memory",此時Redis只響應讀操作

記住: volatile 開頭的策略,只清理過期的key , 而all開頭的策略則不管你過不過期,都會清理。


總結

  • 當client主動訪問key會先對key進行超時判斷,過時的key會立刻刪除。
  • 從節點不會過期掃描,從節點對過期的處理是被動的。 在主從復制環境中,由于上述原因存在已經過期但是沒有刪除的key,在主snapshot時并不包含這些key,因此在slave環境中我們往往看到dbsize較master是更小的。

如果clien永遠都不再get那條key呢?

  • redis會在Master的后臺,每秒10次的執行如下操作:
    隨機選取100個key校驗是否過期,如果有25個以上的key過期了,立刻額外隨機選取下100個key(不計算在10次之內)。可見,如果過期的key不多,它最多每秒回收200條左右,如果有超過25%的key過期了,它就會做得更多。

總結

以上是生活随笔為你收集整理的Redis进阶-Redis对于过期键的三种清除策略的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。