Redis的删除策略与内存淘汰机制

167 阅读2分钟

删除策略

1、立即删除

当key设置有过期时间后,且过期时间到达的时候,由定时器任务立即执行对键的删除操作。 优点:节省内存,到时就删除,快速释放不必要的空间。 缺点:CPU压力过大,无论此时CPU过载有多高,都会占用CPU,会影响Redis服务器的响应时间和吞吐量

2、惰性删除

数据到达过期的时间,不做任何处理。

如果访问该key的时候: 如果未过期,返回数据 如果已过期,删除并返回不存在

优点:节约CPU性能,发现必须删除时才删除

缺点:内存压力大,出现长期占用内存空间的数据

总结:用内存空间换取CPU处理性能(空间换时间)

3、定期删除

Redis会将设置了过期时间的key放入一个独立的字典中,以后会定时遍历这个字典来删除过期的key。 Redis默认每秒进行10次过期扫描。 过期扫描不会遍历过期字典中所有的key,而是采用一种简单的贪心策略。步骤如下:

1.先从过期字典中随机选出20个key

2.删除这20个key中已经过期的key

3.如果过期的key的比例操作25%,就重复步骤1

回收策略

LRU(Least Recently Used)最近最少使用的

  1. noeviction:是redis的默认内存回收策略,返回错误当内存限制达到并且客户端执行会让更多内存被使用的命令
  2. allkeys-lru:在所有的key中回收最近最少使用的(LRU)。
  3. volatile-lru:在过期的集合中尝试回收最近最少使用的
  4. allkeys-random:在所有key中随机随机回收
  5. volatile-random:在过期的key中随机回收
  6. volatile-ttl:回收过期集合的key,并且优先回收存活时间(TTL)较短的key。
  7. allkeys-lfu:所有key中,访问频率最少的
  8. volatile-lfu:在过期时间中,访问频率最少的