Redis的过期删除策略
通过上一篇文章,我们知道了,Redis为什么要设置过期时间以及是如何存储过期时间的,那么就产生了一个新问题,过期的缓存数据要如何删除?这篇文章我们就来讨论这个问题
Redis常用的过期数据的删除策略有两个:
-
🐷惰性删除: 指的是只有当取出key的时候才顺便进行过期检查,如果过期就删除,
优点:这样消耗的CUP少,因为是顺便一起就检查了,不需要额外读取key消耗cpu
缺点:这种懒惰的策略,注定导致很多过期数据都无法被检查,容易堆积导致OOM -
⏳定期删除: 每隔一段时间抽取一批 key 进行过期检查,删除过期数据
优点: 对内存友好,可以检查出更多的过期数据,保证内存利用率
缺点: 对CUP不友好,抽取key的过程需要消耗额外的cup资源
🔴问题: 即使使用了定期删除策略和惰性删除策略,还是会有很多的漏网之鱼,这些没被检查出来的过期数据还是会慢慢堆积,导致内存溢出OOM,那还有什么办法吗?
有!它就是👉 内存淘汰机制
Redis内存淘汰机制
Redis有8大内存淘汰机制:
- volatile-lru:从已设置过期时间的数据集中,挑选最近最少使用的数据淘汰
- volatile-lfu:从已设置过期时间的数据集中,挑选最不经常使用的数据淘汰
- volatile-ttl:从已设置过期时间的数据集,中挑选临近过期的数据淘汰
- volatile-random:从已设置过期时间的数据集,中任意选择数据淘汰
- allkeys-lru:当内存不足以容纳新写入数据时,在键空间中,移除最近最少使用的 key(这个是最常用的)
- allkeys-lfu:当内存不足以容纳新写入数据时,在键空间中,移除最不经常使用的 key
- allkeys-random:从数据集中随机淘汰
- no-eviction:禁止驱逐数据,也就是说当内存不足以容纳新写入数据时,新写入操作会报错(几乎不用)
如果对你有帮助欢迎点赞👍,如有错误欢迎留言指正