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次之內)??梢?#xff0c;如果過期的key不多,它最多每秒回收200條左右,如果有超過25%的key過期了,它就會做得更多。
總結
以上是生活随笔為你收集整理的Redis进阶-Redis对于过期键的三种清除策略的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Redis进阶-如何发现和优雅的处理Bi
- 下一篇: Redis进阶-布隆过滤器