大家好,我是 V 哥,粉絲小A面試阿里,說(shuō)被問(wèn)到 Redis 的內(nèi)存淘汰策略的問(wèn)題,整理這個(gè)筆記給他參考,也分享給大家,如果你遇到這個(gè)問(wèn)題,會(huì)怎么回答呢?
Redis 的內(nèi)存淘汰策略是指當(dāng)Redis的內(nèi)存使用量達(dá)到設(shè)定的上限時(shí),決定哪些數(shù)據(jù)應(yīng)該被移除以便為新數(shù)據(jù)騰出空間的規(guī)則。Redis 提供了多種內(nèi)存淘汰策略,可以通過(guò)配置文件中的 maxmemory-policy
指令來(lái)設(shè)置。以下是 Redis 支持的主要內(nèi)存淘汰策略:
noeviction:這是默認(rèn)策略,當(dāng)內(nèi)存使用達(dá)到限制時(shí),Redis 會(huì)拒絕新的寫(xiě)入操作,并返回錯(cuò)誤,但不會(huì)淘汰任何數(shù)據(jù)。
allkeys-lru:在所有鍵中,基于最近最少使用(LRU)算法淘汰數(shù)據(jù)。Redis 會(huì)維護(hù)一個(gè)近似的 LRU 列表,并不保證完全精確,但是對(duì)大多數(shù)使用場(chǎng)景來(lái)說(shuō)是足夠的。
allkeys-lfu:在所有鍵中,基于最少頻率使用(LFU)算法淘汰數(shù)據(jù)。LFU 算法會(huì)跟蹤每個(gè)鍵的訪問(wèn)頻率,并淘汰訪問(wèn)頻率最低的鍵。
volatile-lru:僅在設(shè)置了過(guò)期時(shí)間的鍵中,基于 LRU 算法淘汰數(shù)據(jù)。
volatile-lfu:僅在設(shè)置了過(guò)期時(shí)間的鍵中,基于 LFU 算法淘汰數(shù)據(jù)。
volatile-random:在設(shè)置了過(guò)期時(shí)間的鍵中隨機(jī)選擇淘汰。
allkeys-random:在所有鍵中隨機(jī)選擇淘汰。
volatile-ttl:在設(shè)置了過(guò)期時(shí)間的鍵中,淘汰那些 TTL(Time To Live)值最小的鍵,也就是即將過(guò)期的鍵。
以上是8種不同的淘汰策略,選擇哪種淘汰策略取決于具體的使用場(chǎng)景和業(yè)務(wù)需求。例如,如果你希望 Redis 作為緩存使用,并且緩存的數(shù)據(jù)大多是臨時(shí)性的,那么可能會(huì)選擇 allkeys-lru
或 volatile-lru
。如果你的應(yīng)用中有明確的熱點(diǎn)數(shù)據(jù),可能會(huì)選擇 allkeys-lfu
或 volatile-lfu
來(lái)確保熱點(diǎn)數(shù)據(jù)不會(huì)被輕易淘汰。
Redis 還提供了一些工具和命令來(lái)幫助監(jiān)控和優(yōu)化內(nèi)存使用,例如 INFO memory
命令可以查看內(nèi)存使用情況,CONFIG SET maxmemory
可以動(dòng)態(tài)調(diào)整內(nèi)存上限。
在 Redis 4.0 版本后引入了 MEMORY
命令,可以更細(xì)致地管理和分析內(nèi)存使用情況。例如,MEMORY USAGE
可以估算鍵值對(duì)的內(nèi)存使用量,MEMORY STATS
可以顯示內(nèi)存使用的詳細(xì)信息。
Redis 的內(nèi)存淘汰是在后臺(tái)異步進(jìn)行的,因此即使達(dá)到了內(nèi)存上限,也不會(huì)立即淘汰數(shù)據(jù),而是在新的寫(xiě)入操作發(fā)生時(shí)根據(jù)配置的策略進(jìn)行淘汰。
noeviction
是 Redis 默認(rèn)的內(nèi)存淘汰策略。當(dāng) Redis 的內(nèi)存使用量達(dá)到 maxmemory
配置的限制時(shí),如果嘗試執(zhí)行可能導(dǎo)致更多內(nèi)存使用的命令(如 SET、LPUSH、SADD 等),Redis 將返回錯(cuò)誤,而不是淘汰任何現(xiàn)有的鍵值對(duì)。
數(shù)據(jù)保留:如果你的應(yīng)用場(chǎng)景中,每個(gè)數(shù)據(jù)項(xiàng)都非常重要,不能丟失,那么 noeviction
策略可以確保即使在高內(nèi)存使用的情況下,數(shù)據(jù)也不會(huì)被自動(dòng)淘汰。
內(nèi)存充足的環(huán)境:如果你的服務(wù)器有足夠的內(nèi)存,或者 Redis 實(shí)例被限制在一個(gè)相對(duì)較小的數(shù)據(jù)集上,那么使用 noeviction
策略可以避免復(fù)雜的淘汰邏輯,簡(jiǎn)化內(nèi)存管理。
消息隊(duì)列:在某些使用 Redis 作為消息隊(duì)列的場(chǎng)景中,可能會(huì)希望確保所有消息都能被處理,而不是在內(nèi)存壓力下丟失消息。
緩存預(yù)熱:在緩存預(yù)熱階段,可能會(huì)希望保持緩存數(shù)據(jù)的完整性,直到緩存穩(wěn)定后再根據(jù)實(shí)際訪問(wèn)模式進(jìn)行淘汰。
配置文件設(shè)置:在 Redis 配置文件 redis.conf
中,可以通過(guò)設(shè)置 maxmemory-policy noeviction
來(lái)啟用 noeviction
策略。
maxmemory-policy noeviction
運(yùn)行時(shí)設(shè)置:也可以在 Redis 運(yùn)行時(shí)使用 CONFIG SET
命令來(lái)動(dòng)態(tài)更改內(nèi)存淘汰策略。
127.0.0.1:6379> CONFIG SET maxmemory-policy noeviction
命令行設(shè)置:如果你使用的是 Redis 命令行工具,也可以在啟動(dòng) Redis 服務(wù)時(shí)通過(guò)命令行參數(shù)設(shè)置。
redis-server --maxmemory-policy noeviction
當(dāng)設(shè)置為 noeviction
時(shí),Redis 會(huì)記錄內(nèi)存使用量,但不會(huì)主動(dòng)淘汰任何鍵值對(duì)。
如果內(nèi)存使用量達(dá)到限制,Redis 會(huì)拒絕那些可能會(huì)增加內(nèi)存使用的命令,并返回錯(cuò)誤信息,如 (error)OOM command not allowed when used memory>'maxmemory'
。
這種策略下,只有當(dāng)客戶(hù)端顯式地刪除鍵值對(duì)或鍵值對(duì)過(guò)期時(shí),內(nèi)存才會(huì)被釋放。
由于不自動(dòng)淘汰數(shù)據(jù),使用 noeviction
策略時(shí)需要更加謹(jǐn)慎地監(jiān)控內(nèi)存使用情況,并確保有足夠的內(nèi)存空間來(lái)處理數(shù)據(jù)的增長(zhǎng)。
使用 noeviction
策略時(shí),需要確保服務(wù)器有足夠的內(nèi)存來(lái)處理數(shù)據(jù)的增長(zhǎng),否則 Redis 可能會(huì)因?yàn)閮?nèi)存不足而無(wú)法處理新的寫(xiě)入請(qǐng)求。
在某些情況下,如果 Redis 長(zhǎng)時(shí)間無(wú)法處理寫(xiě)入請(qǐng)求,可能會(huì)導(dǎo)致客戶(hù)端操作超時(shí)或錯(cuò)誤,影響應(yīng)用程序的正常運(yùn)行。
如果你的應(yīng)用可以容忍數(shù)據(jù)的丟失,或者有其他機(jī)制來(lái)處理數(shù)據(jù)淘汰(如定期清理舊數(shù)據(jù)),那么可以考慮使用其他淘汰策略來(lái)更有效地管理內(nèi)存。
allkeys-lru
是 Redis 的一種內(nèi)存淘汰策略,全稱(chēng)為 "all keys least recently used"。這種策略會(huì)在所有鍵中,包括那些沒(méi)有設(shè)置過(guò)期時(shí)間的鍵,基于最近最少使用算法(LRU)來(lái)淘汰數(shù)據(jù)。
緩存應(yīng)用:在緩存場(chǎng)景中,通常需要保留最近被訪問(wèn)的數(shù)據(jù),以便快速響應(yīng)后續(xù)的讀取請(qǐng)求。allkeys-lru
策略可以確保緩存中的數(shù)據(jù)是最近被訪問(wèn)的,從而提高緩存效率。
數(shù)據(jù)訪問(wèn)模式均勻:如果你的應(yīng)用中所有數(shù)據(jù)的訪問(wèn)模式相對(duì)均勻,沒(méi)有特別明顯的熱點(diǎn)數(shù)據(jù),那么 allkeys-lru
可以作為一個(gè)合理的選擇,因?yàn)樗鼤?huì)淘汰最不活躍的數(shù)據(jù)。
數(shù)據(jù)替換:在某些應(yīng)用中,可能需要定期替換舊數(shù)據(jù)以保持?jǐn)?shù)據(jù)的新鮮度,allkeys-lru
策略可以幫助實(shí)現(xiàn)這一點(diǎn)。
內(nèi)存限制嚴(yán)格:在內(nèi)存使用有嚴(yán)格限制的環(huán)境中,allkeys-lru
可以作為一種自動(dòng)的數(shù)據(jù)淘汰機(jī)制,以確保內(nèi)存使用不會(huì)超過(guò)設(shè)定的限制。
配置文件設(shè)置:在 Redis 配置文件 redis.conf
中,可以通過(guò)設(shè)置 maxmemory-policy allkeys-lru
來(lái)啟用 allkeys-lru
策略。
maxmemory-policy allkeys-lru
運(yùn)行時(shí)設(shè)置:也可以在 Redis 運(yùn)行時(shí)使用 CONFIG SET
命令來(lái)動(dòng)態(tài)更改內(nèi)存淘汰策略。
127.0.0.1:6379> CONFIG SET maxmemory-policy allkeys-lru
命令行設(shè)置:如果你使用的是 Redis 命令行工具,也可以在啟動(dòng) Redis 服務(wù)時(shí)通過(guò)命令行參數(shù)設(shè)置。
redis-server --maxmemory-policy allkeys-lru
LRU 算法:最近最少使用(LRU)是一種常見(jiàn)的頁(yè)面置換算法,它基于這樣一個(gè)假設(shè):如果數(shù)據(jù)最近被訪問(wèn)過(guò),那么將來(lái)被訪問(wèn)的幾率也更高。LRU 算法會(huì)跟蹤每個(gè)數(shù)據(jù)項(xiàng)的訪問(wèn)時(shí)間,并在需要淘汰數(shù)據(jù)時(shí)選擇最久未被訪問(wèn)的數(shù)據(jù)。
淘汰過(guò)程:當(dāng) Redis 的內(nèi)存使用量達(dá)到 maxmemory
限制時(shí),Redis 會(huì)根據(jù) LRU 算法淘汰最久未被訪問(wèn)的鍵值對(duì),直到內(nèi)存使用量降到限制以下。
近似實(shí)現(xiàn):Redis 實(shí)現(xiàn)的 LRU 算法是一個(gè)近似版本,它通過(guò)定期檢查一組隨機(jī)鍵,并淘汰其中最久未被訪問(wèn)的鍵來(lái)工作。這樣可以在不犧牲太多性能的情況下,近似地實(shí)現(xiàn) LRU 算法。
配置樣本大?。篟edis 允許你通過(guò) maxmemory-samples
配置來(lái)調(diào)整用于淘汰決策的鍵樣本大小。增加樣本大小可以提高淘汰決策的準(zhǔn)確性,但可能會(huì)增加 CPU 的使用率。
數(shù)據(jù)丟失:使用 allkeys-lru
策略時(shí),需要意識(shí)到一些最近沒(méi)有被訪問(wèn)的數(shù)據(jù)可能會(huì)被自動(dòng)淘汰,這可能導(dǎo)致數(shù)據(jù)丟失。
性能考慮:雖然 LRU 算法可以提高緩存命中率,但 Redis 需要維護(hù)額外的訪問(wèn)時(shí)間信息,這可能會(huì)對(duì)性能產(chǎn)生一定影響。
監(jiān)控:建議監(jiān)控 Redis 的內(nèi)存使用情況和淘汰事件,以確保系統(tǒng)按預(yù)期工作,并及時(shí)調(diào)整策略或增加內(nèi)存資源。
業(yè)務(wù)適配:在決定使用 allkeys-lru
策略之前,應(yīng)考慮業(yè)務(wù)需求和數(shù)據(jù)訪問(wèn)模式,確保該策略與業(yè)務(wù)目標(biāo)一致。
allkeys-lfu
是 Redis 的一種內(nèi)存淘汰策略,全稱(chēng)為 "all keys least frequently used"。這種策略會(huì)在所有鍵中,包括那些沒(méi)有設(shè)置過(guò)期時(shí)間的鍵,基于最少頻率使用算法(LFU)來(lái)淘汰數(shù)據(jù)。
訪問(wèn)模式不均勻:在數(shù)據(jù)訪問(wèn)模式不均勻的情況下,某些鍵可能被頻繁訪問(wèn),而另一些鍵則很少被訪問(wèn)。allkeys-lfu
策略可以確保經(jīng)常訪問(wèn)的鍵不會(huì)被輕易淘汰。
熱點(diǎn)數(shù)據(jù)保留:如果你的應(yīng)用中有熱點(diǎn)數(shù)據(jù),即那些被頻繁訪問(wèn)的數(shù)據(jù),使用 allkeys-lfu
策略可以確保這些熱點(diǎn)數(shù)據(jù)不會(huì)因?yàn)樽罱钌偈褂盟惴ǘ徽`淘汰。
數(shù)據(jù)重要性:在某些應(yīng)用中,數(shù)據(jù)的重要性與其被訪問(wèn)的頻率成正比。使用 allkeys-lfu
策略可以保留那些被認(rèn)為更重要的數(shù)據(jù)。
避免數(shù)據(jù)抖動(dòng):在一些實(shí)時(shí)性要求高的應(yīng)用中,如推薦系統(tǒng)或?qū)崟r(shí)分析系統(tǒng),使用 allkeys-lfu
策略可以減少因?yàn)閿?shù)據(jù)被淘汰而導(dǎo)致的抖動(dòng)。
配置文件設(shè)置:在 Redis 配置文件 redis.conf
中,可以通過(guò)設(shè)置 maxmemory-policy allkeys-lfu
來(lái)啟用 allkeys-lfu
策略。
maxmemory-policy allkeys-lfu
運(yùn)行時(shí)設(shè)置:也可以在 Redis 運(yùn)行時(shí)使用 CONFIG SET
命令來(lái)動(dòng)態(tài)更改內(nèi)存淘汰策略。
127.0.0.1:6379> CONFIG SET maxmemory-policy allkeys-lfu
命令行設(shè)置:如果你使用的是 Redis 命令行工具,也可以在啟動(dòng) Redis 服務(wù)時(shí)通過(guò)命令行參數(shù)設(shè)置。
redis-server --maxmemory-policy allkeys-lfu
LFU 算法:最少頻率使用(LFU)是一種頁(yè)面置換算法,它基于數(shù)據(jù)項(xiàng)的訪問(wèn)頻率來(lái)淘汰數(shù)據(jù)。LFU 算法會(huì)跟蹤每個(gè)數(shù)據(jù)項(xiàng)的訪問(wèn)次數(shù),并在需要淘汰數(shù)據(jù)時(shí)選擇訪問(wèn)次數(shù)最少的數(shù)據(jù)。
淘汰過(guò)程:當(dāng) Redis 的內(nèi)存使用量達(dá)到 maxmemory
限制時(shí),Redis 會(huì)根據(jù) LFU 算法淘汰訪問(wèn)次數(shù)最少的鍵值對(duì),直到內(nèi)存使用量降到限制以下。
近似實(shí)現(xiàn):Redis 實(shí)現(xiàn)的 LFU 算法是一個(gè)近似版本,它通過(guò)維護(hù)一個(gè)計(jì)數(shù)器來(lái)跟蹤每個(gè)鍵的訪問(wèn)頻率,并在需要淘汰數(shù)據(jù)時(shí)選擇訪問(wèn)頻率最低的鍵。
配置頻率衰減:Redis 允許通過(guò) lfu-decay-time
配置項(xiàng)來(lái)設(shè)置訪問(wèn)頻率的衰減時(shí)間,這有助于平衡最近訪問(wèn)頻率和長(zhǎng)期訪問(wèn)頻率的重要性。
數(shù)據(jù)淘汰:使用 allkeys-lfu
策略時(shí),需要意識(shí)到那些訪問(wèn)頻率較低的數(shù)據(jù)可能會(huì)被自動(dòng)淘汰,這可能導(dǎo)致某些數(shù)據(jù)的丟失。
性能考慮:雖然 LFU 算法可以保留重要的熱點(diǎn)數(shù)據(jù),但 Redis 需要維護(hù)額外的訪問(wèn)計(jì)數(shù)器,這可能會(huì)對(duì)性能產(chǎn)生一定影響。
監(jiān)控:建議監(jiān)控 Redis 的內(nèi)存使用情況和淘汰事件,以確保系統(tǒng)按預(yù)期工作,并及時(shí)調(diào)整策略或增加內(nèi)存資源。
業(yè)務(wù)適配:在決定使用 allkeys-lfu
策略之前,應(yīng)考慮業(yè)務(wù)需求和數(shù)據(jù)訪問(wèn)模式,確保該策略與業(yè)務(wù)目標(biāo)一致。
算法精度:Redis 的 LFU 實(shí)現(xiàn)是一個(gè)近似算法,它通過(guò)定期檢查一組隨機(jī)鍵,并淘汰其中訪問(wèn)頻率最低的鍵來(lái)工作。這樣可以在不犧牲太多性能的情況下,近似地實(shí)現(xiàn) LFU 算法。
volatile-lru
是 Redis 的一種內(nèi)存淘汰策略,全稱(chēng)為 "volatile keys least recently used"。這種策略?xún)H針對(duì)設(shè)置了過(guò)期時(shí)間的鍵,基于最近最少使用算法(LRU)來(lái)淘汰數(shù)據(jù)。
緩存與過(guò)期數(shù)據(jù):在緩存數(shù)據(jù)時(shí),通常會(huì)為緩存項(xiàng)設(shè)置一個(gè)過(guò)期時(shí)間。volatile-lru
策略可以確保在內(nèi)存不足時(shí),最近最少被使用的過(guò)期鍵首先被移除。
臨時(shí)數(shù)據(jù)存儲(chǔ):對(duì)于需要臨時(shí)存儲(chǔ)的數(shù)據(jù),如會(huì)話信息或臨時(shí)計(jì)算結(jié)果,這些數(shù)據(jù)通常有明確的過(guò)期時(shí)間。使用 volatile-lru
策略可以有效地管理這些臨時(shí)數(shù)據(jù)。
熱點(diǎn)數(shù)據(jù)保護(hù):如果你希望保護(hù)那些沒(méi)有設(shè)置過(guò)期時(shí)間的熱點(diǎn)數(shù)據(jù)不被誤淘汰,volatile-lru
策略可以確保只有那些即將過(guò)期的數(shù)據(jù)才會(huì)被考慮淘汰。
數(shù)據(jù)時(shí)效性:在數(shù)據(jù)具有較強(qiáng)時(shí)效性的場(chǎng)景中,如新聞文章或?qū)崟r(shí)數(shù)據(jù),使用 volatile-lru
策略可以確保舊數(shù)據(jù)在內(nèi)存不足時(shí)被優(yōu)先淘汰。
配置文件設(shè)置:在 Redis 配置文件 redis.conf
中,可以通過(guò)設(shè)置 maxmemory-policy volatile-lru
來(lái)啟用 volatile-lru
策略。
maxmemory-policy volatile-lru
運(yùn)行時(shí)設(shè)置:也可以在 Redis 運(yùn)行時(shí)使用 CONFIG SET
命令來(lái)動(dòng)態(tài)更改內(nèi)存淘汰策略。
127.0.0.1:6379> CONFIG SET maxmemory-policy volatile-lru
命令行設(shè)置:如果你使用的是 Redis 命令行工具,也可以在啟動(dòng) Redis 服務(wù)時(shí)通過(guò)命令行參數(shù)設(shè)置。
redis-server --maxmemory-policy volatile-lru
LRU 算法:最近最少使用(LRU)是一種常見(jiàn)的頁(yè)面置換算法,它基于這樣一個(gè)假設(shè):如果數(shù)據(jù)最近被訪問(wèn)過(guò),那么將來(lái)被訪問(wèn)的幾率也更高。LRU 算法會(huì)跟蹤每個(gè)數(shù)據(jù)項(xiàng)的訪問(wèn)時(shí)間,并在需要淘汰數(shù)據(jù)時(shí)選擇最久未被訪問(wèn)的數(shù)據(jù)。
淘汰過(guò)程:當(dāng) Redis 的內(nèi)存使用量達(dá)到 maxmemory
限制時(shí),Redis 會(huì)根據(jù) LRU 算法淘汰最久未被訪問(wèn)的設(shè)置了過(guò)期時(shí)間的鍵值對(duì),直到內(nèi)存使用量降到限制以下。
近似實(shí)現(xiàn):Redis 實(shí)現(xiàn)的 LRU 算法是一個(gè)近似版本,它通過(guò)定期檢查一組隨機(jī)鍵,并淘汰其中最久未被訪問(wèn)的鍵來(lái)工作。這樣可以在不犧牲太多性能的情況下,近似地實(shí)現(xiàn) LRU 算法。
配置樣本大小:Redis 允許你通過(guò) maxmemory-samples
配置來(lái)調(diào)整用于淘汰決策的鍵樣本大小。增加樣本大小可以提高淘汰決策的準(zhǔn)確性,但可能會(huì)增加 CPU 的使用率。
數(shù)據(jù)淘汰:使用 volatile-lru
策略時(shí),需要意識(shí)到那些最近沒(méi)有被訪問(wèn)且即將過(guò)期的數(shù)據(jù)可能會(huì)被自動(dòng)淘汰,這可能導(dǎo)致數(shù)據(jù)丟失。
性能考慮:雖然 LRU 算法可以提高緩存命中率,但 Redis 需要維護(hù)額外的訪問(wèn)時(shí)間信息,這可能會(huì)對(duì)性能產(chǎn)生一定影響。
監(jiān)控:建議監(jiān)控 Redis 的內(nèi)存使用情況和淘汰事件,以確保系統(tǒng)按預(yù)期工作,并及時(shí)調(diào)整策略或增加內(nèi)存資源。
業(yè)務(wù)適配:在決定使用 volatile-lru
策略之前,應(yīng)考慮業(yè)務(wù)需求和數(shù)據(jù)訪問(wèn)模式,確保該策略與業(yè)務(wù)目標(biāo)一致。
數(shù)據(jù)保護(hù):如果你的應(yīng)用中有重要的數(shù)據(jù)沒(méi)有設(shè)置過(guò)期時(shí)間,需要注意 volatile-lru
策略不會(huì)淘汰這些數(shù)據(jù),從而可以保護(hù)這些數(shù)據(jù)不被誤淘汰。
volatile-lfu
是 Redis 的一種內(nèi)存淘汰策略,全稱(chēng)為 "volatile keys least frequently used"。這種策略?xún)H針對(duì)設(shè)置了過(guò)期時(shí)間的鍵,基于最少頻率使用算法(LFU)來(lái)淘汰數(shù)據(jù)。
緩存與頻率限制:在緩存數(shù)據(jù)時(shí),如果某些數(shù)據(jù)項(xiàng)被訪問(wèn)的頻率非常低,即使它們最近被訪問(wèn)過(guò),也可能不是很重要。volatile-lfu
策略可以確保這些不常訪問(wèn)的鍵被優(yōu)先淘汰。
臨時(shí)數(shù)據(jù)存儲(chǔ):對(duì)于有明確過(guò)期時(shí)間的臨時(shí)數(shù)據(jù),如用戶(hù)會(huì)話或緩存的API響應(yīng),volatile-lfu
策略可以在內(nèi)存不足時(shí),根據(jù)訪問(wèn)頻率來(lái)淘汰這些臨時(shí)數(shù)據(jù)。
數(shù)據(jù)時(shí)效性與訪問(wèn)頻率:在數(shù)據(jù)具有較強(qiáng)時(shí)效性且訪問(wèn)頻率不均勻的場(chǎng)景中,volatile-lfu
策略可以結(jié)合時(shí)效性和訪問(wèn)頻率來(lái)決定數(shù)據(jù)的保留優(yōu)先級(jí)。
熱點(diǎn)數(shù)據(jù)與臨時(shí)數(shù)據(jù)的平衡:如果你希望保護(hù)那些頻繁訪問(wèn)的臨時(shí)數(shù)據(jù)不被輕易淘汰,同時(shí)淘汰那些不常訪問(wèn)的臨時(shí)數(shù)據(jù),volatile-lfu
策略可以實(shí)現(xiàn)這種平衡。
配置文件設(shè)置:在 Redis 配置文件 redis.conf
中,可以通過(guò)設(shè)置 maxmemory-policy volatile-lfu
來(lái)啟用 volatile-lfu
策略。
maxmemory-policy volatile-lfu
運(yùn)行時(shí)設(shè)置:也可以在 Redis 運(yùn)行時(shí)使用 CONFIG SET
命令來(lái)動(dòng)態(tài)更改內(nèi)存淘汰策略。
127.0.0.1:6379> CONFIG SET maxmemory-policy volatile-lfu
命令行設(shè)置:如果你使用的是 Redis 命令行工具,也可以在啟動(dòng) Redis 服務(wù)時(shí)通過(guò)命令行參數(shù)設(shè)置。
redis-server --maxmemory-policy volatile-lfu
LFU 算法:最少頻率使用(LFU)是一種頁(yè)面置換算法,它基于數(shù)據(jù)項(xiàng)的訪問(wèn)頻率來(lái)淘汰數(shù)據(jù)。LFU 算法會(huì)跟蹤每個(gè)數(shù)據(jù)項(xiàng)的訪問(wèn)次數(shù),并在需要淘汰數(shù)據(jù)時(shí)選擇訪問(wèn)次數(shù)最少的數(shù)據(jù)。
淘汰過(guò)程:當(dāng) Redis 的內(nèi)存使用量達(dá)到 maxmemory
限制時(shí),Redis 會(huì)根據(jù) LFU 算法淘汰設(shè)置了過(guò)期時(shí)間但訪問(wèn)次數(shù)最少的鍵值對(duì),直到內(nèi)存使用量降到限制以下。
近似實(shí)現(xiàn):Redis 實(shí)現(xiàn)的 LFU 算法是一個(gè)近似版本,它通過(guò)維護(hù)一個(gè)計(jì)數(shù)器來(lái)跟蹤每個(gè)鍵的訪問(wèn)頻率,并在需要淘汰數(shù)據(jù)時(shí)選擇訪問(wèn)頻率最低的鍵。
配置頻率衰減:Redis 允許通過(guò) lfu-decay-time
配置項(xiàng)來(lái)設(shè)置訪問(wèn)頻率的衰減時(shí)間,這有助于平衡最近訪問(wèn)頻率和長(zhǎng)期訪問(wèn)頻率的重要性。
數(shù)據(jù)淘汰:使用 volatile-lfu
策略時(shí),需要意識(shí)到那些訪問(wèn)頻率較低且即將過(guò)期的數(shù)據(jù)可能會(huì)被自動(dòng)淘汰,這可能導(dǎo)致數(shù)據(jù)丟失。
性能考慮:雖然 LFU 算法可以保留重要的熱點(diǎn)數(shù)據(jù),但 Redis 需要維護(hù)額外的訪問(wèn)計(jì)數(shù)器,這可能會(huì)對(duì)性能產(chǎn)生一定影響。
監(jiān)控:建議監(jiān)控 Redis 的內(nèi)存使用情況和淘汰事件,以確保系統(tǒng)按預(yù)期工作,并及時(shí)調(diào)整策略或增加內(nèi)存資源。
業(yè)務(wù)適配:在決定使用 volatile-lfu
策略之前,應(yīng)考慮業(yè)務(wù)需求和數(shù)據(jù)訪問(wèn)模式,確保該策略與業(yè)務(wù)目標(biāo)一致。
算法精度:Redis 的 LFU 實(shí)現(xiàn)是一個(gè)近似算法,它通過(guò)定期檢查一組隨機(jī)鍵,并淘汰其中訪問(wèn)頻率最低的鍵來(lái)工作。這樣可以在不犧牲太多性能的情況下,近似地實(shí)現(xiàn) LFU 算法。
volatile-random
是 Redis 的一種內(nèi)存淘汰策略,全稱(chēng)為 "volatile keys random"。這種策略?xún)H針對(duì)設(shè)置了過(guò)期時(shí)間的鍵,隨機(jī)淘汰數(shù)據(jù)。
過(guò)期數(shù)據(jù)的不確定性:當(dāng)你希望在內(nèi)存不足時(shí)隨機(jī)淘汰一些即將過(guò)期的數(shù)據(jù),而不是基于訪問(wèn)模式或頻率時(shí),volatile-random
是一個(gè)合適的選擇。
簡(jiǎn)化的淘汰邏輯:如果你不需要復(fù)雜的淘汰邏輯,而只是希望在內(nèi)存壓力下隨機(jī)釋放一些空間,那么 volatile-random
策略可以滿足需求。
臨時(shí)數(shù)據(jù)存儲(chǔ):對(duì)于存儲(chǔ)臨時(shí)數(shù)據(jù)的場(chǎng)景,如緩存的會(huì)話信息或臨時(shí)計(jì)算結(jié)果,如果這些數(shù)據(jù)的丟失不會(huì)對(duì)系統(tǒng)造成重大影響,可以使用 volatile-random
策略。
避免熱點(diǎn)數(shù)據(jù)誤傷:如果你希望避免基于訪問(wèn)模式淘汰數(shù)據(jù),從而可能誤傷熱點(diǎn)數(shù)據(jù),volatile-random
策略可以提供一個(gè)更為“公平”的淘汰機(jī)制。
配置文件設(shè)置:在 Redis 配置文件 redis.conf
中,可以通過(guò)設(shè)置 maxmemory-policy volatile-random
來(lái)啟用 volatile-random
策略。
maxmemory-policy volatile-random
運(yùn)行時(shí)設(shè)置:也可以在 Redis 運(yùn)行時(shí)使用 CONFIG SET
命令來(lái)動(dòng)態(tài)更改內(nèi)存淘汰策略。
127.0.0.1:6379> CONFIG SET maxmemory-policy volatile-random
命令行設(shè)置:如果你使用的是 Redis 命令行工具,也可以在啟動(dòng) Redis 服務(wù)時(shí)通過(guò)命令行參數(shù)設(shè)置。
redis-server --maxmemory-policy volatile-random
隨機(jī)淘汰:volatile-random
策略會(huì)在達(dá)到內(nèi)存限制時(shí),從所有設(shè)置了過(guò)期時(shí)間的鍵中隨機(jī)選擇一些鍵進(jìn)行淘汰。
淘汰過(guò)程:Redis 會(huì)維護(hù)一個(gè)設(shè)置了過(guò)期時(shí)間的鍵的列表,當(dāng)需要淘汰數(shù)據(jù)時(shí),它會(huì)從這個(gè)列表中隨機(jī)選擇鍵來(lái)淘汰,直到內(nèi)存使用量降到限制以下。
簡(jiǎn)單且快速:這種策略的實(shí)現(xiàn)相對(duì)簡(jiǎn)單,不需要跟蹤每個(gè)鍵的訪問(wèn)時(shí)間或頻率,因此在執(zhí)行淘汰操作時(shí)可以非??焖?。
公平性:由于淘汰是基于隨機(jī)性的,因此這種策略在一定程度上可以認(rèn)為是“公平”的,因?yàn)樗黄蛴谌魏翁囟ǖ臄?shù)據(jù)。
數(shù)據(jù)淘汰的不確定性:使用 volatile-random
策略時(shí),任何設(shè)置了過(guò)期時(shí)間的數(shù)據(jù)都有可能被淘汰,這可能導(dǎo)致一些重要的數(shù)據(jù)被意外淘汰。
性能考慮:雖然隨機(jī)淘汰策略的實(shí)現(xiàn)簡(jiǎn)單且快速,但頻繁的淘汰操作可能會(huì)對(duì)性能產(chǎn)生一定影響,尤其是在內(nèi)存使用率較高時(shí)。
監(jiān)控:建議監(jiān)控 Redis 的內(nèi)存使用情況和淘汰事件,以確保系統(tǒng)按預(yù)期工作,并及時(shí)調(diào)整策略或增加內(nèi)存資源。
業(yè)務(wù)適配:在決定使用 volatile-random
策略之前,應(yīng)考慮業(yè)務(wù)需求和數(shù)據(jù)的重要性,確保該策略與業(yè)務(wù)目標(biāo)一致。
數(shù)據(jù)保護(hù):如果你的應(yīng)用中有重要的數(shù)據(jù)設(shè)置了過(guò)期時(shí)間,需要注意 volatile-random
策略可能會(huì)淘汰這些數(shù)據(jù),從而需要考慮額外的數(shù)據(jù)保護(hù)措施。
allkeys-random
是 Redis 的一種內(nèi)存淘汰策略,全稱(chēng)為 "all keys random"。這種策略會(huì)在所有鍵中,無(wú)論是否設(shè)置了過(guò)期時(shí)間,隨機(jī)淘汰數(shù)據(jù)。
無(wú)差別數(shù)據(jù):如果你的緩存數(shù)據(jù)沒(méi)有明顯的訪問(wèn)模式差異,即所有數(shù)據(jù)的訪問(wèn)頻率和重要性都差不多,那么 allkeys-random
可以作為一個(gè)簡(jiǎn)單的淘汰策略。
負(fù)載均衡:在分布式緩存環(huán)境中,如果所有節(jié)點(diǎn)的內(nèi)存容量都接近上限,使用 allkeys-random
策略可以確保淘汰操作在各個(gè)節(jié)點(diǎn)之間相對(duì)均衡。
非關(guān)鍵數(shù)據(jù):如果你緩存的數(shù)據(jù)是非關(guān)鍵數(shù)據(jù),即使部分?jǐn)?shù)據(jù)被隨機(jī)淘汰也不會(huì)對(duì)業(yè)務(wù)造成顯著影響,那么這種策略可以減少系統(tǒng)的復(fù)雜性。
臨時(shí)解決方案:在緊急情況下,如內(nèi)存泄漏或其他問(wèn)題導(dǎo)致內(nèi)存壓力突然增大,allkeys-random
可以作為一個(gè)快速反應(yīng)的淘汰策略。
配置文件設(shè)置:在 Redis 配置文件 redis.conf
中,可以通過(guò)設(shè)置 maxmemory-policy allkeys-random
來(lái)啟用 allkeys-random
策略。
maxmemory-policy allkeys-random
運(yùn)行時(shí)設(shè)置:也可以在 Redis 運(yùn)行時(shí)使用 CONFIG SET
命令來(lái)動(dòng)態(tài)更改內(nèi)存淘汰策略。
127.0.0.1:6379> CONFIG SET maxmemory-policy allkeys-random
命令行設(shè)置:如果你使用的是 Redis 命令行工具,也可以在啟動(dòng) Redis 服務(wù)時(shí)通過(guò)命令行參數(shù)設(shè)置。
redis-server --maxmemory-policy allkeys-random
隨機(jī)淘汰:allkeys-random
策略會(huì)在達(dá)到內(nèi)存限制時(shí),從所有鍵中隨機(jī)選擇一些鍵進(jìn)行淘汰。
淘汰過(guò)程:Redis 會(huì)維護(hù)一個(gè)所有鍵的列表,當(dāng)需要淘汰數(shù)據(jù)時(shí),它會(huì)從這個(gè)列表中隨機(jī)選擇鍵來(lái)淘汰,直到內(nèi)存使用量降到限制以下。
簡(jiǎn)單且快速:這種策略的實(shí)現(xiàn)相對(duì)簡(jiǎn)單,不需要跟蹤每個(gè)鍵的訪問(wèn)時(shí)間或頻率,因此在執(zhí)行淘汰操作時(shí)可以非常快速。
公平性:由于淘汰是基于隨機(jī)性的,因此這種策略在一定程度上可以認(rèn)為是“公平”的,因?yàn)樗黄蛴谌魏翁囟ǖ臄?shù)據(jù)。
數(shù)據(jù)淘汰的不確定性:使用 allkeys-random
策略時(shí),任何數(shù)據(jù)都有可能被淘汰,這可能導(dǎo)致一些重要的數(shù)據(jù)被意外淘汰。
性能考慮:雖然隨機(jī)淘汰策略的實(shí)現(xiàn)簡(jiǎn)單且快速,但頻繁的淘汰操作可能會(huì)對(duì)性能產(chǎn)生一定影響,尤其是在內(nèi)存使用率較高時(shí)。
監(jiān)控:建議監(jiān)控 Redis 的內(nèi)存使用情況和淘汰事件,以確保系統(tǒng)按預(yù)期工作,并及時(shí)調(diào)整策略或增加內(nèi)存資源。
業(yè)務(wù)適配:在決定使用 allkeys-random
策略之前,應(yīng)考慮業(yè)務(wù)需求和數(shù)據(jù)的重要性,確保該策略與業(yè)務(wù)目標(biāo)一致。
數(shù)據(jù)保護(hù):如果你的應(yīng)用中有重要的數(shù)據(jù),需要注意 allkeys-random
策略可能會(huì)淘汰這些數(shù)據(jù),從而需要考慮額外的數(shù)據(jù)保護(hù)措施。
volatile-ttl
是 Redis 的一種內(nèi)存淘汰策略,全稱(chēng)為 "volatile keys with the smallest Time To Live"。這種策略?xún)H針對(duì)設(shè)置了過(guò)期時(shí)間的鍵,淘汰那些剩余生存時(shí)間(TTL)最短的鍵。
臨時(shí)數(shù)據(jù)緩存:對(duì)于那些有明確過(guò)期時(shí)間的臨時(shí)數(shù)據(jù),如會(huì)話信息、定時(shí)任務(wù)結(jié)果等,volatile-ttl
策略可以確保這些數(shù)據(jù)在內(nèi)存不足時(shí)按照 TTL 順序被清除。
數(shù)據(jù)時(shí)效性管理:在數(shù)據(jù)具有較強(qiáng)時(shí)效性的場(chǎng)景中,如新聞快訊或?qū)崟r(shí)報(bào)價(jià),volatile-ttl
策略可以確保最接近過(guò)期的數(shù)據(jù)首先被移除。
過(guò)期數(shù)據(jù)優(yōu)先淘汰:如果你希望在內(nèi)存不足時(shí)優(yōu)先淘汰那些即將過(guò)期的數(shù)據(jù),而不是其他數(shù)據(jù),volatile-ttl
提供了一種直接的方式來(lái)實(shí)現(xiàn)這一目標(biāo)。
內(nèi)存優(yōu)化:在內(nèi)存資源有限的情況下,volatile-ttl
策略可以幫助優(yōu)化內(nèi)存使用,確保內(nèi)存中的數(shù)據(jù)盡可能是有用的,即將過(guò)期的數(shù)據(jù)被及時(shí)清除。
配置文件設(shè)置:在 Redis 配置文件 redis.conf
中,可以通過(guò)設(shè)置 maxmemory-policy volatile-ttl
來(lái)啟用 volatile-ttl
策略。
maxmemory-policy volatile-ttl
運(yùn)行時(shí)設(shè)置:也可以在 Redis 運(yùn)行時(shí)使用 CONFIG SET
命令來(lái)動(dòng)態(tài)更改內(nèi)存淘汰策略。
127.0.0.1:6379> CONFIG SET maxmemory-policy volatile-ttl
命令行設(shè)置:如果你使用的是 Redis 命令行工具,也可以在啟動(dòng) Redis 服務(wù)時(shí)通過(guò)命令行參數(shù)設(shè)置。
redis-server --maxmemory-policy volatile-ttl
TTL 淘汰:volatile-ttl
策略會(huì)根據(jù)鍵的剩余生存時(shí)間來(lái)淘汰數(shù)據(jù)。Redis 會(huì)跟蹤每個(gè)設(shè)置了過(guò)期時(shí)間的鍵的 TTL,并在需要淘汰數(shù)據(jù)時(shí)選擇 TTL 最短的鍵。
淘汰過(guò)程:當(dāng) Redis 的內(nèi)存使用量達(dá)到 maxmemory
限制時(shí),Redis 會(huì)查找所有設(shè)置了過(guò)期時(shí)間的鍵,并淘汰那些 TTL 最短的鍵,直到內(nèi)存使用量降到限制以下。
實(shí)時(shí)性:這種策略可以確保內(nèi)存中的數(shù)據(jù)盡可能是最新的,因?yàn)樗鼉A向于淘汰那些即將過(guò)期的數(shù)據(jù)。
配置樣本大?。弘m然 volatile-ttl
策略不涉及 maxmemory-samples
的配置,但它仍然需要定期檢查鍵的 TTL,以便做出淘汰決策。
數(shù)據(jù)淘汰的不確定性:使用 volatile-ttl
策略時(shí),需要注意即使某些數(shù)據(jù)的 TTL 很短,它們也可能在內(nèi)存不足時(shí)被保留,這取決于其他鍵的 TTL 值。
性能考慮:雖然 TTL 淘汰策略的實(shí)現(xiàn)相對(duì)簡(jiǎn)單,但頻繁的淘汰操作可能會(huì)對(duì)性能產(chǎn)生一定影響,尤其是在內(nèi)存使用率較高時(shí)。
監(jiān)控:建議監(jiān)控 Redis 的內(nèi)存使用情況和淘汰事件,以確保系統(tǒng)按預(yù)期工作,并及時(shí)調(diào)整策略或增加內(nèi)存資源。
業(yè)務(wù)適配:在決定使用 volatile-ttl
策略之前,應(yīng)考慮業(yè)務(wù)需求和數(shù)據(jù)的時(shí)效性,確保該策略與業(yè)務(wù)目標(biāo)一致。
數(shù)據(jù)保護(hù):如果你的應(yīng)用中有重要的數(shù)據(jù)設(shè)置了過(guò)期時(shí)間,需要注意 volatile-ttl
策略可能會(huì)淘汰這些數(shù)據(jù),從而需要考慮額外的數(shù)據(jù)保護(hù)措施。
以上是 V 哥整理的筆記,分享給你,歡迎關(guān)注威哥愛(ài)編程,專(zhuān)注技術(shù)學(xué)習(xí)與成長(zhǎng),絕不躺平。
更多建議: