【面试核心】内存不足时-Redis的Key淘汰策略你知道多少

DBC 1.7K 0
  • 背景
    • redis在占用的内存超过指定的maxmemory之后,
    • 通过maxmemory_policy确定redis是否释放内存以及如何释放内存
    • 提供多种策略
  • 策略
    • volatile-lru(least recently used)
      • 最近最少使用算法,从设置了过期时间的键中选择空转时间最长的键值对清除掉;
    • volatile-lfu(least frequently used)
      • 最近最不经常使用算法,从设置了过期时间的键中选择某段时间之内使用频次最小的键值对清除掉;
    • volatile-ttl
      • 从设置了过期时间的键中选择过期时间最早的键值对清除 (删除即将过期的)
    • volatile-random
      • 从设置了过期时间的键中,随机选择键进行清除;
    • allkeys-lru
      • 最近最少使用算法,从所有的键中选择空转时间最长的键值对清除;
    • allkeys-lfu
      • 最近最不经常使用算法,从所有的键中选择某段时间之内使用频次最少的键值对清除;
    • allkeys-random
      • 所有的键中,随机选择键进行删除;
    • noeviction
      • 不做任何的清理工作,在redis的内存超过限制之后,所有的写入操作都会返回错误;但是读操作都能正常的进行;
config配置的时候 下划线_的key需要用中横线-
127.0.0.1:6379> config set maxmemory_policy volatile-lru
(error) ERR Unsupported CONFIG parameter: maxmemory_policy
​
127.0.0.1:6379> config set maxmemory-policy volatile-lru
OK

发表评论 取消回复
表情 图片 链接 代码

分享