内存淘汰策略是过期键删除策略的补充。由于定期删除和惰性删除进行键删除时会存在key没有被删除的情况,所以需要用到内存淘汰策略。
当redis的内存超过最大允许的内存之后,redis会触发内存淘汰策略,删除一些不常用的数据,以保证redis服务器的正常运行。
volatile-lru:最近最少使用。利用LRU算法移除设置了过期时间的key。
allkeys-lru:当内存不足以容纳新写入数据时,从数据集中移除最近最少使用的key。
volatile-ttl:从已设置过期时间的数据集中挑选将要过期的数据淘汰。
volatile-random:从已设置过期时间的数据集中任意选择数据淘汰。
allkeys-random:从数据集中任意选择数据淘汰。
noeviction:禁止删除数据,当内存不足以容纳新写入数据时,新写入操作会报错。
Redis v4.0后增加以下两种:
volatile-lfu:最不经常使用。从已设置过期时间的数据集中挑选最不经常使用的数据淘汰。
allkeys-lfu:当内存不足以容纳新写入数据时,从数据集中移除最不经常使用的key。
内存淘汰策略可以通过配置文件来修改,相应的配置项是maxmemory-policy,默认配置是noeviction