赞
踩
redis 之所以性能比较强,最主要的原因就是基于内存的存储。然而单节点的redis 他的内存大小是不宜过大的,否则会影响持久化和主从同步性能。
经过配置文件可修改redis 的最大内存,
然而当内存使用达到上限时,就无法再次存储更多的数据,所以redis 有两种策略
expire 设置过期时间
有了应用之后,我们要思考两个问题
1.Redis 它如何知道一个key 是否过期呢??
利用两个Dict 数据库字典分别记录key-value ,key-ttl 键值对
2.是不是 TTL到期后,就立马删除了呢??
惰性删除 , 和 周期删除
分析答案:我们要看数据库的结构
并不是在ttl 结束时就立马删除,而是在访问一个 Key 的时候,检查过期时间,如果过期才删除
存在的问题:有很多的过期key 但是呢有没有再次被访问到,key就会一直存在
通过一个定时任务,周期性的抽样部分过期的key ,然后执行删除,执行周期有两种:
总结:
尽管把过期的key 都清理的,但是内存中数据很庞大,仍然有很多的key ,所以要淘汰一部分
大概执行流程
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。