0
点赞
收藏
分享

微信扫一扫

Redis 缓存过期淘汰策略

老北京的热干面 2023-09-17 阅读 15

面试题:

  • 生产上你们的redis内存设置多少?
  • 如何配置、修改redis的内存大小
  • 如果内存满了你怎么办
  • redis清理内存的方式?定期出测除和惰性曲除了解过吗
  • redis缓存淘太策略有哪些?分别是什么?你用那个?
  • redis的LRU了过冯?请手写LRU
  • Iru和lfu算的区别是什么

Redis 内存满了怎么办?

1、redis默认内存多少?在哪里查看如何设置修改?

2、真要打满了会怎么样?如果Redis内存使用超出了设置的最大值会怎样?

改改配置,故意把最大值设为1个byte试试(报OOM异常)

总结:设置了maxmemory的选项,假如redis内存使用达到上限,没有加上过期时间就会导致数摆写满maxmemory。

往Redis里写的数据是怎么没了的?它如何删除的?

Redis过期键的删除策路

1、立即删除

Redis不可能时时刻刻遍历所有被设置了生存时间的key,来检测数据是否已经到达过期时间,然后对它进行删除。

立即删除能保证内存中数据的最大新鲜度,因为它保证过期键值会在过期后马上被删除,其所占用的内存也会随之释放。但是立即删除对cpu是最不友好的。因为删除操作会占用cpu的时间,如果刚好碰上了cpu很忙的时候,比如正在做交集或排序等计算的时候,就会给cpu造成额外的压力,让CPU心累,时时需要删除,忙死。。。。。。。

这会产生大量的性能消耗,同时也会影响数据的读取操作。

总结:对CPU不友好,用处理器性能换取存储空间(拿时间换空间)

2、惰性删除

数据到达过期时间,不做处理。等下次访问该数据时,如果未过期,返回数据 ;发现已过期,删除,返回不存在。

开启隋性淘汰,配置文件中修改:lazyfree-ay-eviction=yes

惰性删除策略的缺点是,它对内存是最不友好的

如果一个键已经过期,而这个键又仍然保留在redis中,那么只要这个过期键不被删除,它所占用的内存就不会释放。在使用惰性删除策略时,如果数据库中有非常多的过期键,而这些过期键又恰好没有被访问到的话,那么它们也许永远也不会被删除(除非用户手动执行FLUSHDB),我们甚至可以将这种情况看作是一种内存泄漏–无用的垃圾数据占用了大量的内存,而服务器却不会自己去释放它们,这对于运行状态非常依赖于内存的Redis服务器来说,肯定不是一个好消息。        

总结:对memory不友好,用存储空间换取处理器性能(空间换时间)

3、定期删除

定期删除策略是前两种策略的折中:定期删除策略每隔一段时间执行一次删除过期键操作并通过限制删除操作执行时长和频率来减少删除操作对CPU时间的影响。

定期删除策略的难点是确定删除操作执行的时长和频率:如果删除操作执行得太频繁或者执行的时间太长,定期删除策略就会退化成立即删除策略,以至于将CPU时间过多地消耗在删除过期键上面。如果删除操作执行得太少,或者执行的时间太短,定期删除策略又会和惰性删除束略一样,出现浪费内存的情况。因此,如果采用定期删除策略的话,服务器必须根据情况,合理地设置删除操作的执行时长和执行频率。

总结:定期抽样key,判断是否过期

Redis缓存汰策略

配置文件

lru和lfu算法的区别是什么

LRU:最近最少使用页面置换算法,淘汰最长时间未被使用的页面,看页面最后一次被使用到发生调度的时间长短,首先淘汰最长时间未被使用的页面。

LFU:最近最不常用页面置换算法,淘汰一定时期内被访问次数最少的页,看一定时间段内页面被使用的频率,淘汰一定时期内被访问次数最少的页。

举例

淘汰策略有哪些?(Redis7)

总结:

2个维度:过期键中筛选、所有键中筛选

4个方面:LRU、LFU、random、ttl

平时用哪一种:

建议:

1、避免存储bigkey

2、开启惰性淘汰,lazyfree-lay-eviction=yes

举报

相关推荐

0 条评论