日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

stringredistemplate设置过期时间_Redis的过期删除策略和内存淘汰机制

發(fā)布時間:2023/12/4 数据库 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 stringredistemplate设置过期时间_Redis的过期删除策略和内存淘汰机制 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

Redis的key可以設(shè)置過期時間,那是否意味著時間一到就會馬上被刪除呢?

Redis的數(shù)據(jù)存儲大小是有限的,假如內(nèi)存不足Redis有什么應(yīng)對策略呢?

本篇文章將介紹一下Redis的過期策略和內(nèi)存淘汰機制。

1、redis的過期策略

1.定時刪除

在設(shè)置key的過期時間的同時,為該key創(chuàng)建一個定時器,讓定時器在key的過期時間來臨時對key進行刪除。優(yōu)點:
保證內(nèi)存被盡快釋放。缺點:
1)若過期key很多,刪除這些key會占用很多的CPU時間,在CPU時間緊張的情況下,CPU不能把所有的時間用來做要緊的事兒,還需要去花時間刪除這些key。
2)定時器的創(chuàng)建耗時,若為每一個設(shè)置過期時間的key創(chuàng)建一個定時器(將會有大量的定時器產(chǎn)生),性能影響嚴(yán)重。

2.惰性刪除

key過期的時候不刪除,每次從數(shù)據(jù)庫獲取key的時候去檢查是否過期,若過期,則刪除,返回null。優(yōu)點:
刪除操作只發(fā)生在從數(shù)據(jù)庫取出key的時候發(fā)生,而且只刪除當(dāng)前key,所以對CPU時間的占用是比較少的,而且此時的刪除是已經(jīng)到了非做不可的地步。缺點:
若大量的key在超出超時時間后,很久一段時間內(nèi),都沒有被獲取過,那么可能發(fā)生內(nèi)存泄露(無用的垃圾占用了大量的內(nèi)存)。

3.定期刪除

如果當(dāng)前庫中沒有一個key設(shè)置了過期時間,直接執(zhí)行下一個庫的遍歷,隨機獲取一個設(shè)置了過期時間的key,檢查該key是否過期,如果過期,刪除key,判斷定期刪除操作是否已經(jīng)達到指定時長,若已經(jīng)達到,直接退出定期刪除。(默認(rèn)每個庫檢測20個key)。優(yōu)點:
1)通過限制刪除操作的時長和頻率,來減少刪除操作對CPU時間的占用--處理"定時刪除"的缺點。
2)定期刪除過期key--處理"惰性刪除"的缺點。缺點:
1)在內(nèi)存友好方面,不如"定時刪除"。
2)在CPU時間友好方面,不如"惰性刪除"。

Redis采用的策略:定期刪除+惰性刪除

2、內(nèi)存淘汰機制

Redis有過期策略,假如你的Redis只能存1G的數(shù)據(jù),你一個請求寫入2G,而你也沒有及時請求key,那么惰性刪除就不生效了,Redis占用內(nèi)存就會越來越高。

Redis可以設(shè)置內(nèi)存大小:

#?maxmemory?
#?設(shè)置Redis最大占用內(nèi)存大小為100
maxmemory?100mb

超過了這個內(nèi)存大小,就會觸發(fā)內(nèi)存淘汰機制

Redis有一個默認(rèn) ?內(nèi)存淘汰機制

#?maxmemory-policy?noeviction

maxmemory-policy一共有8個值,當(dāng)內(nèi)存不足時:

1)noeviction:不刪除,直接返回報錯信息。
2)allkeys-lru:移除最久未使用(使用頻率最少)使用的key。推薦使用這種。
3)volatile-lru:在設(shè)置了過期時間的key中,移除最久未使用的key。
4)allkeys-random:隨機移除某個key。
5)volatile-random:在設(shè)置了過期時間的key中,隨機移除某個key。
6)volatile-ttl:在設(shè)置了過期時間的key中,移除準(zhǔn)備過期的key。
7)allkeys-lfu:移除最近最少使用的key。
8)volatile-lfu:在設(shè)置了過期時間的key中,移除最近最少使用的key。

LRU和LFU的區(qū)別:

LRU是最近最少使用頁面置換算法(Least Recently Used),也就是首先淘汰最長時間未被使用的頁面!

比如有數(shù)據(jù) 1,1,1,2,2,3
此時緩存中已有(1,2)
當(dāng)3加入的時候,得把前面的1淘汰,變成(3,2)

LFU是最近最不常用頁面置換算法(Least Frequently Used),也就是淘汰一定時期內(nèi)被訪問次數(shù)最少的頁!

比如有數(shù)據(jù) 1,1,1,2,2,3
緩存中有(1(3次),2(2次))
當(dāng)3加入的時候,得把后面的2淘汰,變成(1(3次),3(1次))

引申:

假如我的key沒有設(shè)置expire,即沒有設(shè)置過期時間。那么 volatile-lru、volatile-random、volatile-ttl ?就無法執(zhí)行了,和 noeviction 就一樣了。

--end--

總結(jié)

以上是生活随笔為你收集整理的stringredistemplate设置过期时间_Redis的过期删除策略和内存淘汰机制的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。