欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

redis過期key的刪除策略介紹

 更新時間:2025年04月23日 14:58:49   作者:自由de單車  
這篇文章主要介紹了redis過期key的刪除策略,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

在使用redis的過程中,不免會產(chǎn)生過期的key,而這些key過期后并不會實時地馬上被刪除,當這些key數(shù)量累積越來越多,就會占用很多內(nèi)存,因此在redis底層同時使用了三種策略來刪除這些key。

第一種策略:被動刪除

當讀/寫一個key時,redis首先會檢查這個key是否存在,如果存在且已過期,則直接刪除這個key并返回nil給客戶端。

第二種策略:定期刪除

redis中有一系列的定期任務(serverCron),這些任務每隔一段時間就會運行一次,其中就包含清理過期key的任務,運行頻率由配置文件中的hz參數(shù)來控制,取值范圍1~500,默認是10,代表每秒運行10次。

清理過程如下:

  1. 遍歷所有的db
  2. 從db中設(shè)置了過期時間的key的集合中隨機檢查20個key
  3. 刪除檢查中發(fā)現(xiàn)的所有過期key
  4. 如果檢查結(jié)果中25%以上的key已過期,則繼續(xù)重復執(zhí)行步驟2-3,否則繼續(xù)遍歷下一個db

調(diào)大hz將會提高redis定期任務的執(zhí)行頻率,如果你的redis中包含很多過期key的話,可以考慮將這個值調(diào)大,但要注意同時也會增加CPU的壓力,redis作者建議這個值不要超過100。

第三種策略:強制刪除

如果redis使用的內(nèi)存已經(jīng)達到maxmemory配置的值時,會觸發(fā)強制清理策略,清理策略由配置文件的maxmemory-policy參數(shù)來控制

有以下這些清理策略:

  • volatile-lru:使用LRU算法對設(shè)置了過期時間的key進行清理(默認值)
  • allkeys-lru:使用LRU算法對所有key進行清理
  • volatile-lfu:使用LFU算法對設(shè)置了過期時間的key進行清理(redis 4.0版本開始支持)
  • allkeys-lfu:使用LFU算法對所有key進行清理(redis 4.0版本開始支持)
  • volatile-random:對所有設(shè)置了過期時間的key進行隨機清理
  • allkeys-random:從所有key進行隨機清理
  • volatile-ttl:清理生存時間最小的一部分key
  • noeviction:不做任何清理,拒絕執(zhí)行所有的寫操作(如果需要保證數(shù)據(jù)的完整性,可以選擇這個)

為了節(jié)省內(nèi)存和性能上的考慮,上述的清理策略都不需要遍歷所有數(shù)據(jù),而是采用隨機采樣的方法,每次隨機取出特定數(shù)量(由maxmemory-samples配置項控制,默認是5個)的key,然后在這些key中執(zhí)行LRU算法、RANDOM算法、或者是找出TTL時間最小的一個key,然后進行刪除。

注:這個清理過程是阻塞的,直到清理出足夠的內(nèi)存空間才會停止。

關(guān)于big key的清理

在刪除元素數(shù)量很多的集合(set/hash/list/sortedSet)時,無論是使用DEL命令刪除還是redis為了釋放內(nèi)存空間而進行的刪除,在刪除這些big key的時候,會導致redis主線程阻塞。為了解決這個問題,在redis 4.0版本中,提供了lazy free(懶惰刪除)的特性。

使用lazy free刪除big key時,和一個O(1)指令的耗時一樣,亞毫秒級返回,然后把真正刪除key的耗時動作交由bio后臺子線程執(zhí)行。

UNLINK命令

UNLINK命令是與DEL一樣刪除key功能的lazy free實現(xiàn)。

唯一不同的是,UNLINK在刪除集合類型的鍵時,如果集合鍵的元素個數(shù)大于64個,會把真正的內(nèi)存釋放操作,交給單獨的后臺線程來操作,使用示例:

127.0.0.1:6379> UNLINK mylist
(integer) 1

FLUSHALL/FLUSHDB命令

FLUSHALL/FLUSHDB命令也有l(wèi)azy free的實現(xiàn),在命令后加上ASYNC關(guān)鍵字就可以,使用示例:

127.0.0.1:6379> FLUSHALL ASYNC

lazy free相關(guān)配置項

與lazy free相關(guān)的配置項有以下這些,默認值都是no,即關(guān)閉。

lazyfree-lazy-eviction

針對redis內(nèi)存使用達到maxmemory,并設(shè)置有淘汰策略時,在淘汰鍵時是否采用lazy free機制。

注:如果此場景開啟lazy free,可能會使淘汰鍵的內(nèi)存釋放不及時,導致redis不能迅速將內(nèi)存使用下降到maxmemory以下。

lazyfree-lazy-expire

針對設(shè)置有過期時間的key,達到過期后,被redis清理刪除時是否采用lazy free機制,此場景建議開啟。

lazyfree-lazy-server-del

針對有些命令在處理已存在的鍵時,會帶有一個隱式的DEL鍵的操作。如RENAME命令,當目標鍵已存在,redis會先刪除目標鍵,如果這些目標鍵是一個big key,那就會出現(xiàn)阻塞的性能問題。 此參數(shù)設(shè)置就是解決這類問題,建議開啟。

slave-lazy-flush

針對slave進行全量數(shù)據(jù)同步,slave在加載master的RDB文件前,會運行FLUSHALL來清理自己的數(shù)據(jù)場景。

參數(shù)設(shè)置決定是否采用lazy free flush機制。如果內(nèi)存變動不大,建議可開啟。可減少全量同步耗時,從而減少主庫因輸出緩沖區(qū)爆漲引起的內(nèi)存使用增長。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • redis?手機驗證碼實現(xiàn)示例

    redis?手機驗證碼實現(xiàn)示例

    本文主要介紹了redis?手機驗證碼實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • Redis主從復制分步講解使用

    Redis主從復制分步講解使用

    Redis因為其高性能和易用性在我們后端的服務中發(fā)揮了巨大的作用,并且很多重要功能的實現(xiàn)都會依賴redis,本篇我們來了解Redis高可用主從復制,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-09-09
  • 淺談Redis的異步機制

    淺談Redis的異步機制

    命令操作、系統(tǒng)配置、關(guān)鍵機制、硬件配置等會影響 Redis 的性能,還要提前準備好應對異常的方案,本文主要介紹了Redis的異步機制,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-05-05
  • Redis如何使用樂觀鎖(CAS)保證數(shù)據(jù)一致性

    Redis如何使用樂觀鎖(CAS)保證數(shù)據(jù)一致性

    本文主要介紹了Redis如何使用樂觀鎖(CAS)保證數(shù)據(jù)一致性,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Redis在Ubuntu系統(tǒng)上無法啟動的問題排查

    Redis在Ubuntu系統(tǒng)上無法啟動的問題排查

    這篇文章主要介紹了Redis在Ubuntu系統(tǒng)上無法啟動的問題排查,文中通過代碼示例給大家介紹的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下
    2024-08-08
  • redis保存AtomicInteger對象踩坑及解決

    redis保存AtomicInteger對象踩坑及解決

    這篇文章主要介紹了redis保存AtomicInteger對象踩坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • redis中l(wèi)ua腳本使用教程

    redis中l(wèi)ua腳本使用教程

    在使用redis的過程中,發(fā)現(xiàn)有些時候需要原子性去操作redis命令,而redis的lua腳本正好可以實現(xiàn)這一功能。這篇文章主要介紹了redis中l(wèi)ua腳本的簡單使用,需要的朋友可以參考下
    2021-10-10
  • Redis實現(xiàn)Session共享與單點登錄

    Redis實現(xiàn)Session共享與單點登錄

    本文主要介紹了Redis實現(xiàn)Session共享與單點登錄,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • 壓縮Redis里的字符串大對象操作

    壓縮Redis里的字符串大對象操作

    這篇文章主要介紹了壓縮Redis里的字符串大對象操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • 淺談Redis哨兵模式的使用

    淺談Redis哨兵模式的使用

    這篇文章主要介紹了淺談Redis哨兵模式的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12

最新評論