目录
过期策略
set时给key指定一个过期时间ttl
过期时间到了就会立即删除存储的key value以及对应的内存嘛
当然不是,redis的过期策略涉及到惰性删除和定期删除
定期删除
由于redis中的key不是过期就会马上触发删除,引入了一些机制,如定期删除
redis默认是每隔100ms就随机抽取一些设置了过期时间的key,检查其是否过期,如果过期就删除
既然时随机,肯定就会遗漏很多key没有清除,清除的不干净,内存也还被一些过期的key占用
因此还需要惰性删除去走查key触发删除
为什么redis需要随机抽查,而不是类似JVM GC 那样扫描遍历做标记做清除呢?
试想下,keys * 本身就是一个redis的慢查询命令,在生产环境数万甚至更多key,用了可能直接原地爆炸
同理,你怎么指望redis去扫描所有的key,删除过期时间到的呢?不一样会有把redis服务拖垮的风险
惰性删除
惰性删除可以类比惰性加载
惰性加载当对象被使用时才加载初始化
惰性删除 当key过期时间到了,去get 查一下,如果过期了,这时候才会触发删除,返回空
因此redis的过期策略 依赖 redis的「定期删除和惰性删除」
内存淘汰策略
大量key堆积,且有些没有指定过期时间,或者指定的过期时间还没有经过定期删除/惰性删除
如果key继续堆积,很可能导致内存撑爆
这时候就需要redis内存淘汰策略了!
假如没看过redis内存淘汰策略,面试官又恰好问到你,
凭借对操作系统缓存淘汰机制的回忆大概率可以猜测答上一句lru算法,就可以加分
- noeviction:当内存不足以容纳新写入数据时,新写入操作会报错
- allkeys-lru:当内存不足以容纳新写入数据时,在键空间中,移除最近最少使用的key
- allkeys-random:当内存不足以容纳新写入数据时,在键空间中,随机移除某个key
- volatile-lru:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,移除最近最少使用的key
- volatile-random:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,随机移除某个key
- volatile-ttl:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,有更早过期时间的key优先移除
一般最常用的就是 allkeys-lru
转载请注明:汪明鑫的个人博客 » redis的过期策略和内存淘汰策略
说点什么
4 评论 在 "redis的过期策略和内存淘汰策略"
优秀的鑫爷
我是渣渣。。。
优秀的牛逼鑫。
定时、惰性、定期,redis采用 惰性+定期,hhh
强啊我艹