【redis】 LRU 和 LFU 算法

1、簡介

  • Redis 中的 LRU(Least Recently Used)和 LFU(Least Frequently Used)算法是用于決定在內存空間不足時,哪些鍵(key)應該被刪除以釋放空間的策略。
  • 這兩種算法都試圖通過跟蹤鍵的使用情況來優化緩存的性能。

2、LRU? 算法

  • LRU 是一種常用的頁面置換算法,它選擇最久未使用的頁面予以淘汰。
  • 在 Redis 中,LRU 策略用于當內存達到 maxmemory 限制時,選擇哪些鍵進行刪除。然而,Redis 的 LRU 實現并不是嚴格意義上的 LRU,因為它采用了近似 LRU 算法,以節省內存和提高性能。
  • Redis 的近似 LRU 算法通過隨機采樣一部分鍵,并基于這些鍵的訪問時間來決定哪些鍵最久未使用。具體來說,Redis 會為每個鍵維護一個訪問時間戳,當需要淘汰鍵時,它會隨機選擇一部分鍵,并比較這些鍵的訪問時間戳,淘汰最久未使用的鍵。

3、 LFU 算法

  • LFU 是一種基于訪問頻率的頁面置換算法,它選擇訪問頻率最低的頁面予以淘汰。在 Redis 4.0 及更高版本中,引入了 LFU 淘汰策略。
  • LFU 策略跟蹤每個鍵的訪問頻率,并據此決定哪些鍵應該被刪除。與 LRU 不同,LFU 不依賴于時間戳,而是根據鍵的訪問次數來判斷其“新鮮度”。
  • 在 Redis 中,LFU 使用一個 8 位的計數器來記錄每個鍵的訪問頻率,每當鍵被訪問時,計數器就會增加。當需要淘汰鍵時,Redis 會選擇訪問頻率最低的鍵進行刪除。
  • 為了更精確地跟蹤訪問頻率,Redis 的 LFU 計數器采用了衰減機制。如果一個鍵在一段時間內沒有被訪問,它的計數器值會逐漸減小,從而反映出該鍵的“過時”程度。
  • 這種機制有助于 Redis 在淘汰鍵時更好地平衡新數據和舊數據。

4、LRU與LFU算法的區別

  • LRU(Least Recently Used):最近最少使用算法,認為長時間不使用的數據在未來被使用的可能性也很小。Redis中LRU算法的實現采用了隨機抽樣的方式,提升了性能。
  • LFU(Least Frequently Used):最不常用算法,根據數據的訪問頻率來決定哪些數據應當被淘汰。LFU算法更加重視元素的訪問頻率,而非最近一次訪問時間。

5、配置和使用

在 Redis 配置文件中(通常是 redis.conf),你可以通過 maxmemory-policy 選項來設置淘汰策略。對于 LRU 和 LFU 策略,你可以分別使用以下值:

  • volatile-lru:對設置了過期時間的數據使用 LRU 算法淘汰。
  • allkeys-lru:對所有數據使用 LRU 算法淘汰。
  • volatile-lfu:對設置了過期時間的數據使用 LFU 算法淘汰。
  • allkeys-lfu:對所有數據使用 LFU 算法淘汰。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/40250.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/40250.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/40250.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

解決Memcached內存碎片:優化緩存性能的策略

解決Memcached內存碎片:優化緩存性能的策略 Memcached是一個廣泛使用的高性能分布式內存緩存系統,它通過在內存中緩存數據來加速數據檢索操作。然而,隨著時間的推移和緩存操作的進行,Memcached可能會遇到內存碎片問題&#xff0c…

24年河南特崗教師招聘流程+報名流程

河南特崗教師報名流程如下 1.登錄河南省特崗招聘網 登錄河南省特崗招聘網注冊賬號和密碼,賬號可以是手機號或者身份證號,密碼自己設置 2.注冊登錄賬號 注冊完賬號重新登錄賬號,輸入身份證號、手機號、密碼、驗證碼 3.瀏覽考試須知 填寫個人信…

Python 編程快速上手——讓繁瑣工作自動化(第2版)讀書筆記01 Python基礎快速過關

Python 編程快速上手——讓繁瑣工作自動化(第2版)讀書筆記01 Python基礎快速過關 1 python基礎概念 Python提供了高效的高級數據結構,還能簡單有效地面向對象編程。 python運算符順序 **——%——//——/——*——-——python中常見的數據…

Real-Time 3D Graphics with WebGL2

WebGL渲染管線 下圖是WebGL渲染管線的示意圖: Vertex Buffer Objects (VBOs) VBOS中包含了用于描述幾何體的信息。如,幾何體的頂點坐標,法線坐標,顏色,紋理坐標等。 Index Buffer Objects (IBOs) IBOs中包含了描述頂點關系的信…

C#的多線程UI窗體控件顯示方案 - 開源研究系列文章

上次編寫了《LUAgent服務器端工具》這個應用,然后里面需要新啟動一個線程去對文件進行上傳到FTP服務器,但是新線程里無法對應用主線程UI的內容進行更改,所以就需要在線程里設置主UI線程里控件信息的方法,于是就有了此博文。此文記…

Rocky Linux 9 快速安裝docker 教程

前述 CentOS 7系統將于2024年06月30日停止維護服務。CentOS官方不再提供CentOS 及后續版本,不再支持新的軟件和補丁更新。CentOS用戶現有業務隨時面臨宕機和安全風險,并無法確保及時恢復。由于 CentOS Stream 相對不穩定,剛好在尋找平替系統…

idm 支持斷點續傳嗎 idm 斷點續傳如何使用 idm斷點續傳怎么解決 idm下載中斷后無法繼續下載

斷點續傳功能,讓我再也不會懼怕下載大型文件。在斷點續傳的幫助下,用戶可以隨時暫停下載任務,并在空閑時繼續之前的下載進程。下載文件不懼網絡波動,斷點續傳讓下載過程更穩定。有關 idm 支持斷點續傳嗎,idm 斷點續傳如…

JavaScript:if-else類型

目錄 任務描述 相關知識 if語句 if-else語句 匹配問題 編程要求 任務描述 本關任務:根據成績判斷考試結果。 相關知識 在編程中,我們常常根據變量是否滿足某個條件來執行不同的語句。 JavaScript中利用以if關鍵字開頭的條件語句達到以上目的&am…

商城項目回顧

哈哈,準備期末考試去了,項目停了一段時間。現在又忘的差不多了。所以專門寫一篇博客總結前期項目的知識點。 Client軟件包 代碼加總結: 這段代碼實現了一個簡單的客戶端程序,用于與服務器建立連接、發送登錄信息并接收服務器的響…

筆記:tencentos2.4升級gcc4到gcc8.5

由于開發需要將tencentos2.4的GCC版本升級到和cat /proc/version中GCC8.4較接近的版本。 過程如下: 首先 ls -al /etc/yum.repos.d/ 觀察tlinux.repo 可以看到類似: [tlinux] nametlinux-$releasever - tlinux baseurlhttp://mirrors.tencent.com/t…

在主線程和非主線程調用 DispatchQueue.main.sync { }

在 Swift 中,DispatchQueue.main.sync { } 的行為取決于當前執行代碼的線程。以下是詳細的說明: 主線程調用 DispatchQueue.main.sync { } 當在主線程上調用 DispatchQueue.main.sync { } 時,會發生死鎖(Deadlock)。…

|從零搭建網絡| VisionTransformer網絡詳解及搭建

🌜|從零搭建網絡| VisionTransformer系列網絡詳解及搭建🌛 文章目錄 🌜|從零搭建網絡| VisionTransformer系列網絡詳解及搭建🌛🌜 前言 🌛🌜 VIT模型詳解 🌛🌜 VIT模型架…

【Perl CGI腳本全解析】打造動態Web應用的秘籍

標題:【Perl CGI腳本全解析】打造動態Web應用的秘籍 在Web開發的早期,Perl因其強大的文本處理能力和易于編寫的CGI腳本而成為開發動態網站的熱門選擇。盡管現代Web開發已經涌現了許多新的技術和框架,但Perl CGI腳本依然在某些場景下發揮著作…

計算機相關專業入門

IT專業入門,高考假期預習指南 七月來臨,各省高考分數已揭榜完成。而高考的完結并不意味著學習的結束,而是新旅程的開始。對于有志于踏入IT領域的各位小伙伴,這個假期是開啟探索IT世界的絕佳時機。作為該領域的前行者,…

mybatis、mybatis-plus插件開發,實現數據脫敏功能

首先說一下mybatis中四大組件的作用,下面開發的插件攔截器會使用 四大組件Executor、StatementHandler、ParameterHandler、ResultSetHandler Executor: Executor 是 MyBatis 中的執行器,負責 SQL 語句的執行工作。它通過調度 StatementHan…

python基礎語法 004-3流程控制- while

1 while while 主要用的場景沒有 for 循環多。 while循環&#xff1a;主要運行場景 我不知道什么時候結束。。。不知道運行多少次 1.1 基本用法 # while 4 > 3: #一直執行 # print("hell0")while 4 < 3: #不會打印&#xff0c;什么都沒有print("…

IT之旅啟航:高考后IT專業預習全攻略

?作者主頁&#xff1a; Mr.Zwq??個人簡介&#xff1a;一個正在努力學技術的Python領域創作者&#xff0c;擅長爬蟲&#xff0c;逆向&#xff0c;全棧方向&#xff0c;專注基礎和實戰分享&#xff0c;歡迎咨詢&#xff01; 您的點贊、關注、收藏、評論&#xff0c;是對我最大…

opencv 處理圖像去噪的幾種方法

OpenCV 提供了多種圖像去噪的方法&#xff0c;以下是一些常見的去噪技術以及相應的 Python 代碼示例&#xff1a; 均值濾波&#xff1a;使用像素鄰域的灰度均值代替該像素的值。 import cv2 import numpy as np import matplotlib.pyplot as pltimg cv2.imread("4.jpg&qu…

Java知識點大綱

文章目錄 第一階段&#xff1a;JavaSE1、面向對象編程(基礎)1)面向過程和面向對象區別2)類和對象的概述3)類的屬性和方法4)創建對象內存分析5)構造方法(Construtor)及其重載6)對象類型的參數傳遞7)this關鍵字詳解8)static關鍵字詳解9)局部代碼塊、構造代碼塊和靜態代碼塊10)pac…

2-24 基于圖像處理的細胞計數方法

基于圖像處理的細胞計數方法。經過初次二值化、中值濾波后二值化、優化后二值化圖像、填充背景色的二進制圖像、開運算后的圖像一系列運算后&#xff0c;進行標簽設置&#xff0c;最終得到細胞總數。程序已調通&#xff0c;可直接運行。 2-24 細胞計數方法 中值濾波后二值化 - …