在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

Redis缓存中的淘汰策略有哪些

142次阅读
没有评论

共计 1971 个字符,预计需要花费 5 分钟才能阅读完成。

本篇内容主要讲解“Redis 缓存中的淘汰策略有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让丸趣 TV 小编来带大家学习“Redis 缓存中的淘汰策略有哪些”吧!

我们知道 Redis 缓存使用内存来保存数据,但内存大小毕竟有限,随着要缓存的数据量越来越大,有限的缓存空间不可避免地会被写满。这时候就需要缓存的淘汰策略去删除数据。

Redis 缓存的淘汰策略

Redis 的淘汰策略,根据是否会进行数据淘汰可以把它们分成两类:

不进行数据淘汰的策略,只有 noeviction 这一种。

会进行淘汰的 7 种其他策略。

会进行淘汰的 7 种策略,我们可以再进一步根据淘汰候选数据集的范围把它们分成两类:

在设置了过期时间的数据中进行淘汰,包括 volatile-random、volatile-ttl、volatile-lru、volatile-lfu(Redis 4.0 后新增)四种。

在所有数据范围内进行淘汰,包括 allkeys-lru、allkeys-random、allkeys-lfu(Redis 4.0 后新增)三种。

在 redis3.0 之前,默认是 volatile-lru;在 redis3.0 之后(包括 3.0),默认淘汰策略则是 noeviction

noeviction 策略

noeviction 表示不淘汰数据,当缓存数据满了,有新的写请求进来,Redis 不再提供服务,而是直接返回错误。

根据过期时间的淘汰策略

volatile-random、volatile-ttl、volatile-lru、volatile-lfu 四种策略是针对已经设置了过期时间的键值对。到键值对的到期时间到了或者 Redis 内存使用量达到了 maxmemory 阈值,Redis 会根据这些策略对键值对进行淘汰;

volatile-ttl 在筛选时,会针对设置了过期时间的键值对,根据过期时间的先后进行删除,越早过期的越先被删除。

volatile-random 就像它的名称一样,在设置了过期时间的键值对中,进行随机删除。

volatile-lru 会使用 LRU 算法筛选设置了过期时间的键值对。

volatile-lfu 会使用 LFU 算法选择设置了过期时间的键值对。

所有数据范围内的淘汰策略

allkeys-lru、allkeys-random、allkeys-lfu 这三种策略淘汰的数据范围扩大到所有的键值对,无论这些键值对是否设置了过期时间,筛选数据进行淘汰的规则是:

allkeys-random 策略,从所有键值对中随机选择并删除数据;

allkeys-lru 策略,使用 LRU 算法在所有数据中进行筛选。

allkeys-lfu 策略,使用 LFU 算法在所有数据中进行筛选。

关于 LRU 算法

LRU 算法即是最近最常使用算法,由于 LRU 会使用一个链表去维护使用的数据列表,当使用的数据越多,其移动元素时就会越耗时,这不可避免地会影响到 Redis 主线程。为此 Redis 对 lru 算法做了些简化。

LRU 策略的核心思想:如果一个数据刚刚被访问,那么这个数据肯定是热数据,还会被再次访问。

按照这个核心思想,Redis 中的 LRU 策略,会在每个数据对应的 RedisObject 结构体中设置一个 lru 字段,用来记录数据的访问时间戳。在进行数据淘汰时,LRU 策略会在候选数据集中淘汰掉 lru 字段值最小的数据(也就是访问时间最久的数据)。

所以,在数据被频繁访问的业务场景中,LRU 策略的确能有效留存访问时间最近的数据。而且,因为留存的这些数据还会被再次访问,所以又可以提升业务应用的访问速度。

具体做法是,在访问键值对时,redis 会记录最近一次访问的时间戳。在 redis 决定淘汰数据时,会随机挑选 N 个数据,把它们作为一个候选集合,把最小的时间戳给筛选出去。当下一次要淘汰数据时,会挑选比第一次挑选的候选集合时间戳值要小的数据进入新的候选集合。当数据达到 maxmemory-samples 时,将最小的值给淘汰掉。

通过该命令可以设置挑选的候选集合数 CONFIG SET maxmemory-samples N

使用建议

依据策略的特性,可以针对不同场景选择不同的策略去淘汰数据。

当缓存数据没有明显的冷热之分,即数据的访问频率差距不大,建议使用 allkeys-random 随机策略淘汰数据;

当数据有明显的冷热之分,建议使用 allkeys-lru 或者 volatile-lru 算法,将最近最常访问的数据留在缓存数据中;

当业务中存在置顶需求,即不会过期的数据,这类一般不会设置过期时间,可以采用 volatile-lru 策略。这样这类数据就不会被淘汰,而其它数据可以根据 lru 规则进行淘汰。

到此,相信大家对“Redis 缓存中的淘汰策略有哪些”有了更深的了解,不妨来实际操作一番吧!这里是丸趣 TV 网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-26发表,共计1971字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 性生大片免费观看性 | 性刺激的欧美三级视频中文 | 精品人妻一区二区三区四区在线 | 男人扒开添女人下部免费视频 | 免费啪啪网 | 久久视频精品538在线久 | 国产成人av无码专区亚洲av | 久久厕所视频 | 伊在人亚洲香蕉精品区 | 日本xxxxxxxxx69中国 | 欧美顶级少妇做爰hd | 亚洲av成人精品一区二区三区 | 精品国产一区二区三区久 | 中文字幕av一区中文字幕天堂 | 妺妺窝人体色www在线 | 亚洲区小说 | h人成在线看免费视频 | 中文字幕一区二区三区四区五区人 | 四虎www| 91在线看视频 | 国产成人精品日本亚洲网址 | 牛牛在线精品第一区 | a级高清观看视频在线看 | 国产免费成人在线视频 | 亚洲欧洲日产国码无码久久99 | 亚洲人成网站18禁止大 | 亚洲国产成人久久笫一页 | 国内亚州视频在线观看 | 亚洲综合国产成人丁香五月激情 | 精品一区二区三区高清免费观看 | 欧美日本另类 | 青青青青久久国产片免费精品 | 偷窥村妇洗澡毛毛多 | 色宅男看片午夜大片啪啪 | 四虎在线观看视频 | 免费激情网 | 亚洲国产精品综合久久2007 | 亚洲不卡一区二区三区在线 | 免费国产va在线观看 | 国产无遮挡又黄又爽在线视频 | 国产精品66|