Redis的定期删除和惰性删除

惰性删除

Redis并不是对于指定数据到了开发者设定好的生命结束时间就自动被删除,因为对这个内容进行不断轮询检测的性能消耗太大了,只有到了用户想要访问这个key所对应的内容的时候,Redis才会首先去检测这个key还是否有效,然后才将其进行删除。

这种做法虽然极大程度上利用了CPU但是会触发内存泄漏问题,因此就引入了定期删除机制。

定期删除

Redis的主线程每隔一段时间就会抽查一部分的key值,如果抽到过期的就会立即删除,如果抽到过期的占抽取总数的占比较大,主线程就会立刻触发的下一次的定期删除工作。

这样不会导致主线程一直都在定期删除吗?主线程内部有超时熔断机制,在执行定期删除任务达到一定时间就会立刻停下,转而对client请求进行处理。

注:4.0版本后,主线程对过期数据的清理工作,变成了主线程先查看释放内容大小,如果内存很大,就会摘除该指针并交由laze_free去清理,大大加快了释放空间的效率。

相关推荐
资深web全栈开发1 小时前
PostgreSQL Schema 最佳实践:架构师的命名与组织艺术
数据库·postgresql
麦聪聊数据2 小时前
利用实时数据管道与 SQL2API 重构企业自动化审计架构
数据库·sql·低代码
麦聪聊数据2 小时前
重构开放生态:利用 QuickAPI 跨越遗留系统与敏捷交付的工程实践
数据库·sql·低代码·restful
百结2147 小时前
Mysql数据库操作
数据库·mysql·oracle
keep one's resolveY7 小时前
时区问题解决
数据库
Leinwin8 小时前
OpenClaw 多 Agent 协作框架的并发限制与企业化规避方案痛点直击
java·运维·数据库
qq_417695058 小时前
机器学习与人工智能
jvm·数据库·python
漫随流水8 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
ego.iblacat8 小时前
MySQL 服务基础
数据库·mysql