Redis的定期删除和惰性删除

惰性删除

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

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

定期删除

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

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

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

相关推荐
倔强的石头_5 分钟前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB2 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
jiayou641 天前
KingbaseES 表级与列级加密完全指南
数据库·后端
用户3074596982072 天前
Redis 延时队列详解
redis
GBASE2 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
烤代码的吐司君2 天前
Redis 数据结构 ZSet, BIT, HyperLogLog,Geo 空间数据
redis·后端
xiezhr2 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩3 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3504 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3504 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库