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.淘汰策略

 

大概执行流程

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是小晴晴呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值