Redis过期键删除策略
第一章 Redis单线程为什么这么快?
第二章 Redis的持久化机制
第三章 Redis过期键的删除策略
Redis过期键删除策略
前言
想必大家都直到Redis它是一个key-Value结构的数据库,它的key是可以设置过期时间的,过了这是时间key就会被清除掉。那么当我们设置了过期时间后Reids它是怎么处理的呢?
一、惰性过期
只有当访问了一个key时,才会判断该key是否已经过期,过期则清除(类似于延迟加载),该策略可以最大化的节约资源,却队内存非常不友好。气短清空可能出现大量的过期key没有再次被访问,从而不会被清除,占用大量内存资源。
二、定时过期(Redis中没有用到)
给每一个key设置一个定时器,时间到了指定过期时间,由定时器去清除这个key 这种策略对内存相对友好但是对CPU就不太友好了,因为要实时监控key有没有过期
三、定期清理
每隔一段时间就扫描 一定数量
的数据库的expires字典中一定数量的key,并清除其中已经过期的key。该策略是前面两种策略的一种折中方案,通过调整定时扫描的时间间隔和每次扫描的限定耗时,可以在不同情况下使得CPU和内存资源达到最优的平衡水平
expires字典会保存所有设置了过期时间的key的过期时间数据,其中key是只想键空间中的某个键的指针,value是该键的毫秒精度的unix时间戳表示的过期时间。键空间是指该Redis集群中保存的所有键
总结
Redis中同时使用的惰性过期和定期清理这两种策略。