Redis内存淘汰策略及内存管理

本文详细介绍了Redis的过期策略,包括定期删除和惰性删除的结合使用,以及内存淘汰策略,如LRU、LFU等。在Redis内存满时,可通过配置内存淘汰策略或增大内存来应对。同时,文章讨论了LRU和LFU算法在Redis中的实现和应用场景。
摘要由CSDN通过智能技术生成

1. Redis 的过期策略以及内存淘汰策略

比如你 Redis 只能存 5G 数据,可是你写了 10G,那会删 5G 的数据。怎么删的?还有,你的数据已经设置了过期时间,但是时间到了,内存占用率还是比较高?答案: redis 采用的是 定期删除 + 惰性删除 两种策略

定期删除:用一个定时器来负责监视 key,过期则自动删除。虽然内存及时释放,但是十分消耗 CPU 资源。在大并发请求下,CPU 要将时间应用在处理请求,而不是删除 key,因此没有采用这一策略

1.1. 过期策略

1.1.1. 定期删除 + 惰性删除是如何工作的

定期删除:Redis 默认会每隔 100ms 随机抽取检查是否有过期的 Key,如有过期的 Key 则删除。如果只采用定期删除策略,会导致很多 Key 过期了,而没有删除。于是,惰性删除就派上用场了

惰性删除:就是在你获取某个 Key 的时候 Redis 会检查一下,这个 Key 如果设置了过期时间那么是否过期了?如果过期了此时就会删除。并不是 Key 到了过期时间,就会被删除掉

1.1.2. 定期删除 + 惰性删除就没问题了么

不是的,如果定期删除没有删除掉某个 Key。然后你也没即时去请求这个 Key,也就是说惰性删除也没生效。这样,Redis 的内存会越来越高,那么就应该采用内存淘汰机制

1.2. 内存淘汰策略

Redis 提供了 6 种的内存淘汰策略,配置方法如下

 maxmemory-policy volatile-lru
  • noeviction默认使用的策略,当内存不足以容纳新写入数据时,新写入操作会报错。不推荐使用
  • allkeys-lru:当内存不足以容纳新写入数据时,移除最近最少使用的 key。也就是从所有 key<
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值