当前位置:   article > 正文

Redis 内存回收(策略:过期Key 处理,内存淘汰策略)_redis容量满了以后回收key

redis容量满了以后回收key

redis 之所以性能比较强,最主要的原因就是基于内存的存储。然而单节点的redis 他的内存大小是不宜过大的,否则会影响持久化和主从同步性能。

经过配置文件可修改redis 的最大内存,

然而当内存使用达到上限时,就无法再次存储更多的数据,所以redis 有两种策略

1.过期策略

   expire 设置过期时间 

 有了应用之后,我们要思考两个问题

  1.Redis 它如何知道一个key 是否过期呢??

          利用两个Dict 数据库字典分别记录key-value ,key-ttl 键值对

  2.是不是 TTL到期后,就立马删除了呢??

          惰性删除 , 和 周期删除

分析答案:我们要看数据库的结构

   1.1 惰性删除

并不是在ttl 结束时就立马删除,而是在访问一个 Key 的时候,检查过期时间,如果过期才删除

 

 存在的问题:有很多的过期key 但是呢有没有再次被访问到,key就会一直存在

1.2 周期删除

 通过一个定时任务,周期性的抽样部分过期的key ,然后执行删除,执行周期有两种:

 

 总结:

 尽管把过期的key 都清理的,但是内存中数据很庞大,仍然有很多的key ,所以要淘汰一部分

 2.淘汰策略

 

大概执行流程

 

 

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号