搜尋
首頁資料庫RedisRedis刪除策略的三種方法及逐出演算法實例分析

一、前言

在文章開始之前,我先問大家一個問題:當我們使用指令:expire key second給一個key設定過期時間,過期時間一到,這個key對應的過期資料真的被伺服器立即刪除了嗎?答案是並不會立即刪除。知道了這個答案,就來看看Redis中如何處理過期的數據。

二、Redis中的資料特徵

Redis是一種記憶體級資料庫,所有資料都存放在記憶體中,記憶體中的資料可以透過TTL指令取得其狀態,有三種狀態: 

##XX具有時效性的資料-1永久有效的資料##-2

三、時效性資料儲存結構

Redis刪除策略的三種方法及逐出演算法實例分析

當我們用指令設定過期資料後,資料對應的位址會放在expires空間中,儲存方式是哈希,儲存的value是過期時間。

四、資料刪除策略

資料刪除策略目標:在記憶體佔用與CPU佔用之間尋找一種平衡,顧此失彼都會造成整體redis效能的下降,甚至引發伺服器宕機或記憶體外洩

1、定時刪除

  • #創建一個定時器,當key設定有過期時間,且過期時間到達時,由定時器任務立即執行對鍵的刪除操作

  • 優點:節約內存,到時就刪除,快速釋放不必要的內存佔用

  • 缺點:CPU壓力很大,無論CPU此時負載量多高,均佔用CPU,會影響redis伺服器回應時間與指令吞吐量

Redis刪除策略的三種方法及逐出演算法實例分析

2、惰性刪除

  • 資料到達過期時間,不做處理。等下次存取該數據時,會呼叫expireIfNeeded()函數來判斷該數據是否過期: 如果未過期,返回數據,發現已過期,刪除,返回不存在

  • #優點:節約CPU效能,發現必須刪除的時候才刪除

  • #缺點:記憶體壓力很大,出現長期佔用記憶體的資料

Redis刪除策略的三種方法及逐出演算法實例分析

3、定期刪除

Redis刪除策略的三種方法及逐出演算法實例分析

##流程分析:

  • Redis伺服器啟動初始化時,讀取配置server.hz的值,預設為10

  • 然後每秒鐘執行10次

    serverCron()方法,該方法用來偵測伺服器

  • serverCron()方法又會呼叫databasesCron( )方法,該方法是用來遍歷資料庫的,redis預設有16個資料庫,從第一個資料庫開始

  • ##databasesCron()

    方法又會呼叫activeExpireCycle()方法,該方法會對每一個expires[*]逐一進行偵測,每次執行250ms/server.hz;對某個expires [*]偵測時,隨機挑選W個key偵測

  • 如果偵測到key逾時,則刪除key;如果一輪中刪除的key的數量>W25% ,循環該過程;如果一輪中刪除的key的數量≤W25%,檢查下一個
  • expires[*]

    ,0-15循環。其中W取值=ACTIVE_EXPIRE_CYCLE_LOOKUPS_PER_LOOP屬性值

  • 如果activeExpireCycle()執行時間到期,下次再從current_db繼續向下執行
  • 參數current_db用於記錄activeExpireCycle() 進入哪個expires[*] 執行

Redis刪除策略的三種方法及逐出演算法實例分析

  • 總結:

    週期性輪詢redis庫中的時效性數據,採用隨機抽取的策略,利用過期數據佔比的方式控制刪除頻度

  • 內存壓力不是很大,長期佔用內存的冷數據會被持續清理
  • 五、刪除策略對比

指示結果 #狀態
已經過期的資料 或被刪除的資料或未定義的資料
定時刪除惰性刪除#會定期刪除##記憶體定期隨機清理每秒花費固定的CPU資源維護記憶體隨機抽查,重點抽查

六、逐出演算法

1、概念引入

當新資料進入redis時,如果記憶體不足怎麼辦? Redis使用記憶體儲存數據,在執行每個指令前,會呼叫freeMemoryIfNeeded()偵測記憶體是否足夠。如果記憶體不符合新加入資料的最低儲存需求,redis要暫時刪除一些資料為目前指令清理儲存空間。清理資料的策略稱為逐出演算法。

注意:逐出資料的過程不是100%能夠清理出足夠的可使用的記憶體空間,如果不成功則反覆執行。當所有資料都嘗試完畢後,如果無法達到記憶體清理的要求,將出現錯誤訊息。

Redis刪除策略的三種方法及逐出演算法實例分析

2、八種配置

偵測易失資料(可能會過期的資料集server.db[i].expires )

節約內存,無佔用 不分時段佔用CPU資源,頻度高 拿時間換空間
#記憶體佔用嚴重 延時執行,CPU利用率高 拿空間換時間
volatile-lru 挑選最近最少使用的資料淘汰
volatile-lfu 挑選最近使用次數最少的資料淘汰
volatile-ttl 挑選將要過期的資料淘汰
volatile-random 任意選擇資料淘汰

#偵測全庫資料(所有資料集server.db[i].dict )

allkeys-lru 挑選最近最少使用的資料淘汰
allkeys-lfu 挑選最近使用次數最少的資料淘汰
allkeys-random 任意選擇資料淘汰

放棄資料驅逐:

no-enviction 禁止驅逐資料(redis4.0中預設策略)
#

以上是Redis刪除策略的三種方法及逐出演算法實例分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:亿速云。如有侵權,請聯絡admin@php.cn刪除
REDIS:鍵值數據存儲的指南REDIS:鍵值數據存儲的指南May 02, 2025 am 12:10 AM

Redis是一個開源的內存數據結構存儲,用作數據庫、緩存和消息代理,適合需要快速響應和高並發的場景。 1.Redis使用內存存儲數據,提供微秒級的讀寫速度。 2.它支持多種數據結構,如字符串、列表、集合等。 3.Redis通過RDB和AOF機制實現數據持久化。 4.使用單線程模型和多路復用技術高效處理請求。 5.性能優化策略包括LRU算法和集群模式。

REDIS:緩存,會話管理等REDIS:緩存,會話管理等May 01, 2025 am 12:03 AM

Redis的功能主要包括緩存、會話管理和其他功能:1)緩存功能通過內存存儲數據,提高讀取速度,適用於電商網站等高頻訪問場景;2)會話管理功能在分佈式系統中共享會話數據,並通過過期時間機制自動清理;3)其他功能如發布-訂閱模式、分佈式鎖和計數器,適用於實時消息推送和多線程系統等場景。

REDIS:探索其核心功能和好處REDIS:探索其核心功能和好處Apr 30, 2025 am 12:22 AM

Redis的核心功能包括內存存儲和持久化機制。 1)內存存儲提供極快的讀寫速度,適用於高性能應用。 2)持久化通過RDB和AOF兩種方式確保數據不丟失,選擇依據應用需求。

REDIS的服務器端操作:它提供的REDIS的服務器端操作:它提供的Apr 29, 2025 am 12:21 AM

Redis'sserver-sedierations offerfunctions andTriggersForexeCutingCompleXoperationsontheserver.1)函數functionsAllowCompOustomoperationsInlua,JavaScript,javaScript,orredis'sscriptinglanguigh,增強效率和增強性。 2)

REDIS:數據庫還是服務器?揭開角色的神秘面紗REDIS:數據庫還是服務器?揭開角色的神秘面紗Apr 28, 2025 am 12:06 AM

redisisbothadatabaseandaserver.1)asadatabase,ituseSin-memorystorageforfastaccess,ifealforreal-timeapplications andCaching.2)Asaserver,ItsupportsPub/submessagingAndluAsessingandluAsessingandluascriptingftingftingftingftingftingftingftingfinteral-timecommunicationandserverserverserverserverserverserverserver-soperations。

REDIS:NOSQL方法的優勢REDIS:NOSQL方法的優勢Apr 27, 2025 am 12:09 AM

Redis是NoSQL數據庫,提供高性能和靈活性。 1)通過鍵值對存儲數據,適合處理大規模數據和高並發。 2)內存存儲和單線程模型確保快速讀寫和原子性。 3)使用RDB和AOF機制進行數據持久化,支持高可用性和橫向擴展。

REDIS:了解其架構和目的REDIS:了解其架構和目的Apr 26, 2025 am 12:11 AM

Redis是一种内存数据结构存储系统,主要用作数据库、缓存和消息代理。它的核心特点包括单线程模型、I/O多路复用、持久化机制、复制与集群功能。Redis在实际应用中常用于缓存、会话存储和消息队列,通过选择合适的数据结构、使用管道和事务、以及进行监控和调优,可以显著提升其性能。

REDIS與SQL數據庫:關鍵差異REDIS與SQL數據庫:關鍵差異Apr 25, 2025 am 12:02 AM

Redis和SQL數據庫的主要區別在於:Redis是內存數據庫,適用於高性能和靈活性需求;SQL數據庫是關係型數據庫,適用於復雜查詢和數據一致性需求。具體來說,1)Redis提供高速數據訪問和緩存服務,支持多種數據類型,適用於緩存和實時數據處理;2)SQL數據庫通過表格結構管理數據,支持複雜查詢和事務處理,適用於電商和金融系統等需要數據一致性的場景。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器