过期数据
过期数据的删除策略:定时删除、定期删除、惰性删除
定时删除
在设置键的过期时间的同时,创建一个定时器,让定时器在键的过期时间来临时,立即执行对键的删除操作。
优点:节约内存,到时就删除,快速释放掉不必要的内存占用
缺点:CPU压力很大,无论CPU此时负载量多高,均占用CPU,会影响redis服务器响应时间和指令吞吐量
用处理器性能换空间
定期删除(主动删除?)
redis默认每间隔100ms就随机抽取一些设置了过期时间的key检查其是否过期,如果过期就删除。周期性轮询redis库中的时效性数据,采用随机抽取的策略,利用过期数据占比的方式控制删除频度
CPU性能占用设置有峰值,检测频度可自定义设置
内存压力不是很大,长期占用内存的冷数据会被持续清理
惰性删除
定期删除可能会导致很多过期key到了时间并没有被删除调。所以就有了 惰性删除。如果过期的key定期删除没有删调,当再次使用get获取这个key的时候,redis会删除这个key,这就是所谓的惰性删除
优点:节约CPU性能,发现必须删除的时候才删除
缺点:内存压力很大,出现长期占用内存的数据
逐出算法/内存淘汰策略(主动删除?)
新数据进入时,如果内存不足的话,redis要临时删除一些数据为当前指令清理存储空间。
最大可使用内存max