网站 栏目添加 文章不显示,网上如何注册公司,建站公司合同模板,手机端网站建设公司【Redis】Redis内存过期策略和内存淘汰策略 文章目录 【Redis】Redis内存过期策略和内存淘汰策略1. 过期策略1.1 惰性删除1.2 周期删除1.2.1 SLOW模式1.2.2 FAST模式 2. 淘汰策略 1. 过期策略
Redis本身是一个典型的key-value内存存储数据库#xff0c;因此所有的key、value都…【Redis】Redis内存过期策略和内存淘汰策略 文章目录 【Redis】Redis内存过期策略和内存淘汰策略1. 过期策略1.1 惰性删除1.2 周期删除1.2.1 SLOW模式1.2.2 FAST模式 2. 淘汰策略 1. 过期策略
Redis本身是一个典型的key-value内存存储数据库因此所有的key、value都保存在之前学习过的Dict结构中。不过在其database结构体中有两个Dict一个用来记录key-value另一个用来记录key-TTL。 Redis中有两种常见的过期策略
惰性删除周期删除 1.1 惰性删除
惰性删除顾名思义并不是在 TTL 到期后就立刻删除而是在访问一个 key 的时候检查该 key 的存活时间如果已经给过期才执行删除。这种策略减少了对每个键的访问检查对 Redis 的性能更友好但可能导致过期键在一段时间内仍保留在 Redis 中。 1.2 周期删除
周期删除顾名思义是通过一个定时任务周期性的抽样部分过期的key然后执行删除执行周期有两种
Redis 服务初始化函数 initServer() 中设置定时任务按照 server.hz 的频率来执行过期 key 清理模式为 SLOW。Redis 的每个事件循环前会调用 beforeSleep() 函数执行过期key清理模式为 FAST.
这种策略确保了键在过期后尽快从 Redis 中删除但需要在每次访问时进行额外的检查会对 Redis 的性能产生一定的影响。 1.2.1 SLOW模式
SLOW模式的规则
执行频率受 server.hz 影响默认为10即每秒执行10次每个执行周期 100ms。执行清理耗时不超过一次执行周期的25%默认SLOW模式耗时不超过25ms。逐个遍历db逐个遍历db中的bucket抽取20个key判断是否过期。如果没达到时间上限(25ms)并且过期key比例大于10%则再进行一次抽样否则结束。 1.2.2 FAST模式
FAST模式的规则(过期key比例小于10%不执行)
执行频率受beforeSleep()调用频率影响但两次FAST模式间隔不低于2ms执行清理耗时不超过1ms逐个遍历db逐个遍历db中的bucket抽取20个key判断是否过期如果没达到时间上限1ms并且过期key比例大于10%再进行一次抽样否则结束 2. 淘汰策略
内存淘汰就是当Redis内存使用达到设置的上限时主动挑选部分key删除以释放更多内存的流程。Redis会在处理客户端命令的方法 processCommand() 中尝试做内存淘汰 Redis支持8种不同的策略来选择要删除的key
noeviction不淘汰任何key但是内存满时不允许写入新数据默认策略。volatile-ttl对设置了TTL的key比较key剩余的TTL值TTL越小越先被淘汰。allkeys-random对全体key随机进行淘汰也就是直接从 db-dict 中随机挑选。volatile-random对设置了TTL的key随机进行淘汰也就是从 db-expires 中随机挑选。allkeys-lru对全体key基于LRU算法进行淘汰。volatile-lru对设置了TTL的key基于LRU算法进行淘汰。allkeys-lfu对全体key基于LFU算法进行淘汰。volatile-lfu对设置了TTL的key基于LFU算法进行淘汰
比较容易混淆的有两个
LRU(Least Recently Used)最少最近使用用当前时间减去最后一次访问时间这个值越大则淘汰的优先级越高。LFU(Least Frequently Used)最少频率使用统计每个key的访问频率值越小淘汰优先级越高。
Redis的数据都会被封装为 RedisObject 结构 LFU的访问次数之所以叫做逻辑访问次数是因为并不是每次key被访问都计数而是通过运算
生成0~1之间的随机数R计算 (旧次数 * lfu_log_factor 1)记录为P如果 R P 则计数器 1且最大不超过255访问次数会随时间衰减距离上一次访问时间每隔 lfu_decay_time 分钟计数器 -1