您好,登錄后才能下訂單哦!
這篇文章給大家介紹redis 中怎么實(shí)現(xiàn)熱點(diǎn)更新策略,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。
redis過期策略采用的是定期刪除+惰性刪除,
定期刪除指redis會(huì)定期會(huì)檢查帶有過期時(shí)間的key,如果key已過期則刪除。但是定期檢查不會(huì)檢查所有的key[檢查所有的key也將會(huì)是中災(zāi)難],只會(huì)隨機(jī)抽查。
定期刪除只會(huì)隨機(jī)抽查,會(huì)有很多到期的key未清理。當(dāng)這個(gè)key被查詢但是已經(jīng)過期,redis會(huì)刪除該key并返回空
定期刪除+惰性刪除結(jié)合使用,就能夠保證:一個(gè)key如果過期了,肯定會(huì)被刪除了。
定期刪除+惰性刪除會(huì)遺留很多失效數(shù)據(jù)未被檢查到也未被調(diào)用。這個(gè)時(shí)候內(nèi)存達(dá)到閥值。redis關(guān)于采用以下機(jī)制。
noeviction:當(dāng)內(nèi)存使用達(dá)到閥值的時(shí)候,所有引起申請(qǐng)內(nèi)存的命令會(huì)報(bào)錯(cuò);
allkeys-lru:嘗試回收,最近未使用或者使用比較少的鍵。(范圍是:所有的鍵)
volatile-lru:嘗試回收,最近未使用或者使用比較少的鍵。(范圍是:設(shè)置了過期時(shí)間的鍵)
allkeys-random:隨機(jī)移除某個(gè)key。(范圍是:所有的鍵)
volatile-random:隨機(jī)移除某個(gè)key。(范圍是:設(shè)置了過期時(shí)間的鍵)
volatile-ttl:回收過期時(shí)間較短的key。(范圍是:設(shè)置了過期時(shí)間的鍵)
redis的淘汰策略:默認(rèn)是 noeviction
maxmemory <bytes>:為0時(shí)指使用內(nèi)存不受限制
maxmemory-policy:默認(rèn)noeviction
關(guān)于redis 中怎么實(shí)現(xiàn)熱點(diǎn)更新策略就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。