Redis6内存不足时的Key淘汰策略

当Redis内存使用达到maxmemory配置的上限时,会根据maxmemory_policy策略淘汰部分键值对。本文介绍了volatile-lru、volatile-lfu、volatile-ttl、volatile-random、allkeys-lru、allkeys-lfu、allkeys-random和noeviction等8种策略的工作原理,帮助理解Redis如何在内存不足时释放内存。
摘要由CSDN通过智能技术生成

内存不足时Redis的Key内存淘汰策略

  • 背景

    • redis在指定内存占用超过maxmemorey指定的值之后
    • 通过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的内存超过限制之后,所有的写入操作都会返回错误;但是读操作都能正常的进行;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

RobertTeacher

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值