我們首先來了解一下Redis的內(nèi)存淘汰機(jī)制。
概述
redis默認(rèn)是每隔 100ms 就隨機(jī)抽取一些設(shè)置了過期時(shí)間的key,檢查其是否過期,如果過期就刪除。注意這里是隨機(jī)抽取的。為什么要隨機(jī)呢?你想一想假如 redis 存了幾十萬個(gè) key ,每隔100ms就遍歷所有的設(shè)置過期時(shí)間的 key 的話,就會(huì)給 CPU 帶來很大的負(fù)載!
優(yōu)點(diǎn)
缺點(diǎn)
總結(jié)
用處理器性能換取存儲(chǔ)空間 (拿時(shí)間換空間)
key過期的時(shí)候不刪除,每次從數(shù)據(jù)庫獲取key的時(shí)候去檢查是否過期,若過期,則刪除,返回null。
優(yōu)點(diǎn)
缺點(diǎn)
總結(jié)
用存儲(chǔ)空間換取處理器性能(拿空間換時(shí)間)
如果當(dāng)前庫中沒有一個(gè)key設(shè)置了過期時(shí)間,直接執(zhí)行下一個(gè)庫的遍歷,隨機(jī)獲取一個(gè)設(shè)置了過期時(shí)間的key,檢查該key是否過期,如果過期,刪除key,判斷定期刪除操作是否已經(jīng)達(dá)到指定時(shí)長,若已經(jīng)達(dá)到,直接退出定期刪除。(默認(rèn)每個(gè)庫檢測20個(gè)key)
優(yōu)點(diǎn)
缺點(diǎn)
簡述
Redis有過期策略,假如你的Redis只能存1G的數(shù)據(jù),你一個(gè)請(qǐng)求寫入2G,而你也沒有及時(shí)請(qǐng)求key,那么惰性刪除就不生效了,Redis占用內(nèi)存就會(huì)越來越高。
Redis可以設(shè)置內(nèi)存大?。?br />
# maxmemory bytes> # 設(shè)置Redis最大占用內(nèi)存大小為100 maxmemory 100mb
超過了這個(gè)內(nèi)存大小,就會(huì)觸發(fā)內(nèi)存淘汰機(jī)制,Redis有一個(gè)默認(rèn)配置,這個(gè)是Redis的默認(rèn) 內(nèi)存淘汰機(jī)制:
# maxmemory-policy noeviction
maxmemory-policy一共有8個(gè)值,當(dāng)內(nèi)存不足時(shí):
LRU是最近最少使用頁面置換算法(Least Recently Used),也就是首先淘汰最長時(shí)間未被使用的頁面!
比如有數(shù)據(jù) 1,1,1,2,2,3 此時(shí)緩存中已有(1,2) 當(dāng)3加入的時(shí)候,得把前面的1淘汰,變成(3,2)
LFU是最近最不常用頁面置換算法(Least Frequently Used),也就是淘汰一定時(shí)期內(nèi)被訪問次數(shù)最少的頁!
比如有數(shù)據(jù) 1,1,1,2,2,3 緩存中有(1(3次),2(2次)) 當(dāng)3加入的時(shí)候,得把后面的2淘汰,變成(1(3次),3(1次))
Redis啟動(dòng)前會(huì)先檢查AOF文件,不存在才會(huì)去加載RDB文件,因?yàn)锳OF的數(shù)據(jù)完整性高,最多也就損失1秒的數(shù)據(jù)。
到此這篇關(guān)于淺談Redis緩存有哪些淘汰策略的文章就介紹到這了,更多相關(guān)Redis緩存淘汰策略內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
標(biāo)簽:北京 江蘇 大慶 臺(tái)州 吉安 朝陽 楊凌 果洛
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《淺談Redis緩存有哪些淘汰策略》,本文關(guān)鍵詞 淺談,Redis,緩,存有,哪些,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。