redis深度剖析六(内存淘汰策略)

内存淘汰策略

redis一共有8总内存淘汰策略,核心是lru和lfu两种算法;淘汰策略和过期策略是不同的,淘汰策略是指当存进redis中的key都不过期时,但是redis此时却已经满了,所以此时会走淘汰策略;
在这里插入图片描述

lru算法

lru是least recently used的缩写表示最近最少使用;

基本原理

通常的lru算法是基于双向链表和hashmap,双向链表利于增删,hashmap利于查找,若采用的是头插法,则最近使用的数据就插入链表头部,并且放进hashmap中;原理如下图所示;
在这里插入图片描述

redis中的lru算法实现

redis的lru算法在3.0版本之前是随机选取5个数进行判断,可以通过修改redis.conf文件中的maxmemory-samples修改;在3.0版本之后,redis维护了一个大小为16的候选池,按照空闲时间由大到小进行排序,所以每次随机采集一个key,往侯选池中添加数据时,有四种情况,数据结构上是基于数组;
在这里插入图片描述

lfu算法

lfu是least frequently used的缩写表示最近最少频率使用;

基本原理

通常lfu算法原理如下,这种数据结构和jdk8中引入的stampedLock很像;stampedLock具体原理见
https://www.cnblogs.com/zxporz/p/11642176.html
在这里插入图片描述

redis中的lfu算法实现

https://www.cnblogs.com/linxiyue/p/10955533.html
有个计数器,但并不是每次都增加1,数据越长时间没使用,计数器增加1就越难,并且数据越长时间没使用,计数器的值还会往下减;计数器值越大,可以约等于访问越频繁;
和上述通常情况是一致的;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

orcharddd_real

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值