在 Redis 的运行内存达到了某个阀值,就会触发内存淘汰机制,这个阀值就是我们设置的最大运行内存,此值在 Redis 的配置文件中可以找到,配置项为 maxmemory。
那么Redis 内存淘汰策略有哪些?
Redis 内存淘汰策略共有八种,这八种策略大体分为「不进行数据淘汰」和「进行数据淘汰」两类策略。下面说下比较常用的。
如果 Redis 的内存使用率达到最大限制,它会停止接受写入请求,并开始采取下列措施之一:
1. 异步删除失效 key:Redis 开始删除过期和设置了过期时间的 key,以释放一些内存。Redis 使用的这个机制是基于惰性删除的。
2. 最近最少使用淘汰算法(LRU):Redis 会删除最近最少使用的 key 来释放内存。
如果 Redis 的内存持续被占满,并且 Redis 停止了所有写入请求,那么系统将最终停止响应读取请求,这将导致 Redis 无法提供服务,进而影响系统的可用性。
因此,为了避免 Redis 内存被占满,我们需要设置最大内存限制、使用恰当的过期策略,并定期检查内存使用情况。