這篇文章帶大家來聊聊Redis快取中的8種淘汰策略,看看該怎麼使用它們,希望對大家有幫助!
我們知道Redis
快取使用記憶體來保存數據,但記憶體大小畢竟有限,隨著要快取的資料量越來越大,有限的快取空間不可避免地會被寫滿。這時候就需要快取的淘汰策略去刪除資料。 【相關推薦:Redis影片教學】
Redis快取的淘汰策略
Redis的淘汰策略,根據是否會進行資料淘汰可以把它們分成兩類:
- 不進行資料淘汰的策略,只有noeviction 這一種。
- 會進行淘汰的 7 種其他策略。
會進行淘汰的7 種策略,我們可以再進一步根據淘汰候選資料集的範圍把它們分成兩類:
在設定了過期時間的資料中進行淘汰,包括volatile-random、volatile-ttl、volatile-lru、volatile-lfu(Redis 4.0 後新增)四種。
在所有資料範圍內進行淘汰,包括 allkeys-lru、allkeys-random、allkeys-lfu(Redis 4.0 後新增)三種。
在redis3.0之前,預設是volatile-lru
;在redis3.0之後(包括3.0),預設淘汰策略則是noeviction
noeviction 策略
noeviction表示不淘汰數據,當快取資料滿了,有新的寫入請求進來, Redis不再提供服務,而是直接回傳錯誤。
根據過期時間的淘汰策略
volatile-random、volatile-ttl、volatile-lru、volatile-lfu 四種策略是針對已經設定了過期時間的鍵值對。到鍵值對的到期時間到了或Redis記憶體使用量達到了maxmemory
閾值,Redis會根據這些策略對鍵值對進行淘汰;
- volatile-ttl 在篩選時,會針對設定了過期時間的鍵值對,根據過期時間的先後進行刪除,越早過期的越先被刪除。
- volatile-random 就像它的名稱一樣,在設定了過期時間的鍵值對中,進行隨機刪除。
- volatile-lru 會使用 LRU 演算法篩選設定了過期時間的鍵值對。
- volatile-lfu 會使用 LFU 演算法選擇設定了過期時間的鍵值對。
所有資料範圍內的淘汰策略
allkeys-lru、allkeys-random、allkeys-lfu 這三種策略淘汰的資料範圍擴大到所有的鍵值對,無論這些鍵值對是否設定了過期時間,篩選資料進行淘汰的規則是:
allkeys-random 策略,從所有鍵值對中隨機選擇並刪除資料;
allkeys-lru 策略,使用LRU 演算法在所有資料中進行篩選。
allkeys-lfu 策略,使用 LFU 演算法在所有資料中進行篩選。
關於LRU演算法
LRU演算法即是最近最常使用演算法,由於LRU會使用一個鍊錶去維護使用的資料列表,當使用的資料越多,其移動元素時就會越耗時,這不可避免地會影響Redis主執行緒。為此Redis對lru演算法做了一些簡化。
LRU 策略的核心思想:如果一個數據剛剛被訪問,那麼這個數據肯定是熱數據,還會再次訪問。
依照這個核心思想,Redis 中的 LRU 策略,會在每個資料對應的 RedisObject 結構體中設定一個 lru 字段,用來記錄資料的存取時間戳記。在進行資料淘汰時,LRU 策略會在候選資料集中淘汰掉 lru 欄位值最小的資料(也就是存取時間最長的資料)。
所以,在資料被頻繁存取的業務場景中,LRU 策略的確能有效留存存取時間最近的資料。而且,因為留存的這些資料還會再次被訪問,所以又可以提升業務應用程式的存取速度。
具體做法是,在存取鍵值對時,redis會記錄最近一次造訪的時間戳記。當redis決定淘汰數據時,會隨機挑選N個數據,把它們當作一個候選集合,把最小的時間戳給篩選出去。當下次要淘汰資料時,會挑選比第一次挑選的候選集合時間戳值要小的資料進入新的候選集合。當資料達到maxmemory-samples 時,將最小的值給淘汰掉。
透過此指令可以設定挑選的候選集合數CONFIG SET maxmemory-samples N
使用建議
依據策略的特性,可以針對不同場景選擇不同的策略來淘汰資料。
- 當快取資料沒有明顯的冷熱之分,即資料的存取頻率差距不大,建議使用
allkeys-random
隨機策略淘汰資料; - 當數據有明顯的冷熱之分,建議使用
allkeys-lru
或volatile-lru
演算法,將最近最常存取的資料留在快取資料中; - 當業務中存在置頂需求,即不會過期的數據,這類一般不會設定過期時間,可以採用
volatile-lru
策略。這樣這類數據就不會被淘汰,而其它數據可以根據lru規則進行淘汰。
更多程式相關知識,請造訪:程式設計入門! !
以上是淺析Redis快取中的8種淘汰策略的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Redis的數據庫方法包括內存數據庫和鍵值存儲。 1)Redis將數據存儲在內存中,讀寫速度快。 2)它使用鍵值對存儲數據,支持複雜數據結構,如列表、集合、哈希表和有序集合,適用於緩存和NoSQL數據庫。

Redis是一個強大的數據庫解決方案,因為它提供了極速性能、豐富的數據結構、高可用性和擴展性、持久化能力以及廣泛的生態系統支持。 1)極速性能:Redis的數據存儲在內存中,讀寫速度極快,適合高並發和低延遲應用。 2)豐富的數據結構:支持多種數據類型,如列表、集合等,適用於多種場景。 3)高可用性和擴展性:支持主從復制和集群模式,實現高可用性和水平擴展。 4)持久化和數據安全:通過RDB和AOF兩種方式實現數據持久化,確保數據的完整性和可靠性。 5)廣泛的生態系統和社區支持:擁有龐大的生態系統和活躍社區,

Redis的關鍵特性包括速度、靈活性和豐富的數據結構支持。 1)速度:Redis作為內存數據庫,讀寫操作幾乎瞬時,適用於緩存和會話管理。 2)靈活性:支持多種數據結構,如字符串、列表、集合等,適用於復雜數據處理。 3)數據結構支持:提供字符串、列表、集合、哈希表等,適合不同業務需求。

Redis的核心功能是高性能的內存數據存儲和處理系統。 1)高速數據訪問:Redis將數據存儲在內存中,提供微秒級別的讀寫速度。 2)豐富的數據結構:支持字符串、列表、集合等,適應多種應用場景。 3)持久化:通過RDB和AOF方式將數據持久化到磁盤。 4)發布訂閱:可用於消息隊列或實時通信系統。

Redis支持多種數據結構,具體包括:1.字符串(String),適合存儲單一值數據;2.列表(List),適用於隊列和棧;3.集合(Set),用於存儲不重複數據;4.有序集合(SortedSet),適用於排行榜和優先級隊列;5.哈希表(Hash),適合存儲對像或結構化數據。

Redis計數器是一種使用Redis鍵值對存儲來實現計數操作的機制,包含以下步驟:創建計數器鍵、增加計數、減少計數、重置計數和獲取計數。 Redis計數器的優勢包括速度快、高並發、持久性和簡單易用。它可用於用戶訪問計數、實時指標跟踪、遊戲分數和排名以及訂單處理計數等場景。

使用 Redis 命令行工具 (redis-cli) 可通過以下步驟管理和操作 Redis:連接到服務器,指定地址和端口。使用命令名稱和參數向服務器發送命令。使用 HELP 命令查看特定命令的幫助信息。使用 QUIT 命令退出命令行工具。

Redis集群模式通過分片將Redis實例部署到多個服務器,提高可擴展性和可用性。搭建步驟如下:創建奇數個Redis實例,端口不同;創建3個sentinel實例,監控Redis實例並進行故障轉移;配置sentinel配置文件,添加監控Redis實例信息和故障轉移設置;配置Redis實例配置文件,啟用集群模式並指定集群信息文件路徑;創建nodes.conf文件,包含各Redis實例的信息;啟動集群,執行create命令創建集群並指定副本數量;登錄集群執行CLUSTER INFO命令驗證集群狀態;使


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

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

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

Dreamweaver Mac版
視覺化網頁開發工具

Dreamweaver CS6
視覺化網頁開發工具