首页 > 编程知识 正文

redis淘汰策略和删除策略,redis定期删除策略

时间:2023-05-03 09:58:46 阅读:273620 作者:1037

淘汰策略

noeviction 不删除数据,将不能进行新的写入。扩容后恢复正常。
allkeys-lru 选择最近最少使用的key进行删除来保证可以写入新的数据。丢弃数据来换取可用性。
volatile-lru 从设置了过期时间的key中选择最近最少使用的key进行删除来保证新的写入,如果没有设置过期时间的key把容量占满了,同样将不能进行新的写入,扩容后恢复正常。
volatile-ttl 从设置了过期时间的key中选择即将过期的key进行删除来保证新的写入,如果没有设置过期时间的key把容量占满了,同样将不能进行新的写入,扩容后恢复正常

redis 删除key过期

redis key 设置过期时间:
并没有定时任务去扫描每个过期key 然后执行删除,业务正常运行读写,再有大量定时任务执行会消耗cpu 内存 从而引爆io。
默认给key 一个时间戳,当下次触发key的时候,判断时间过期了,再删除这个key。也就是淘汰策略的惰性删除。

redis采用的是定期删除+惰性删除策略。
为什么不用定时删除策略?
定时删除,用一个定时器来负责监视key,过期则自动删除。虽然内存及时释放,但是十分消耗CPU资源。在大并发请求下,CPU要将时间应用在处理请求,而不是删除key,因此没有采用这一策略.

定期删除+惰性删除是如何工作的呢?
定期删除,redis默认每个100ms检查,是否有过期的key,有过期key则删除。需要说明的是,redis不是每个100ms将所有的key检查一次,而是随机抽取进行检查(如果每隔100ms,全部key进行检查,redis岂不是卡死)。因此,如果只采用定期删除策略,会导致很多key到时间没有删除。
惰性删除也就是说在你获取某个key的时候,redis会检查一下,这个key如果设置了过期时间那么是否过期了?如果过期了此时就会删除。

采用定期删除+惰性删除就没其他问题了么?
不是的,如果定期删除没删除key。然后你也没即时去请求key,也就是说惰性删除也没生效。这样,redis的内存会越来越高。那么就应该采用内存淘汰机制。

在redis.conf中有一行配置
maxmemory-policy volatile-lru

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。