赞
踩
Redis本身是一个典型的key-value内存存储数据库,因此所有的key、value都保存在之前学习过的Dict结构中。不过在其database结构体中,有两个Dict:一个用来记录key-value;另一个用来记录key-TTL。
Redis中有两种常见的过期策略:
惰性删除:顾名思义并不是在 TTL 到期后就立刻删除,而是在访问一个 key 的时候,检查该 key 的存活时间,如果已经给过期才执行删除。这种策略减少了对每个键的访问检查,对 Redis 的性能更友好,但可能导致过期键在一段时间内仍保留在 Redis 中。
周期删除:顾名思义是通过一个定时任务,周期性的抽样部分过期的key,然后执行删除,执行周期有两种:
initServer()
中设置定时任务,按照 server.hz 的频率来执行过期 key 清理,模式为 SLOW。beforeSleep()
函数,执行过期key清理,模式为 FAST.这种策略确保了键在过期后尽快从 Redis 中删除,但需要在每次访问时进行额外的检查,会对 Redis 的性能产生一定的影响。
SLOW模式的规则:
server.hz
影响,默认为10,即每秒执行10次,每个执行周期 100ms。FAST模式的规则(过期key比例小于10%不执行):
内存淘汰:就是当Redis内存使用达到设置的上限时,主动挑选部分key删除以释放更多内存的流程。Redis会在处理客户端命令的方法 processCommand()
中尝试做内存淘汰:
Redis支持8种不同的策略来选择要删除的key:
比较容易混淆的有两个:
Redis的数据都会被封装为 RedisObject 结构:
LFU的访问次数之所以叫做逻辑访问次数,是因为并不是每次key被访问都计数,而是通过运算:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。