Redis 淘汰策略

     Redis 是一个使用键值对存储数据的内存中数据结构存储系统,它支持多种类型的数据结构,如字符串(strings),列表(lists),集合(sets),有序集合(sorted sets)以及散列表(hashes)。当内存不足以容纳所有数据时,Redis 可以配置不同的淘汰策略来决定哪些数据应该被移除。

1. 无淘汰策略 (noeviction)
  • 策略说明: 当内存使用达到配置的 maxmemory 限制时,所有引起内存增加的命令都会报错。
2. 全部随机淘汰 (allkeys-random)
  • 策略说明: 当达到内存限制时,随机移除任意键。
3. 最近最少使用淘汰 (allkeys-lru)
  • 策略说明: 当达到内存限制时,移除最近最少使用的键。
4. 最近最少使用淘汰(基于样本)(volatile-lru)
  • 策略说明: 从已设置过期时间的键中选择最近最少使用的键进行淘汰。
5. 随机淘汰(仅限设置了过期时间的键)(volatile-random)
  • 策略说明: 从已设置过期时间的键中随机选择键进行淘汰。
6. 最少使用淘汰(仅限设置了过期时间的键)(volatile-ttl)
  • 策略说明: 从已设置过期时间的键中选择将要过期的键进行淘汰。
7. 最近最少使用淘汰(基于样本,仅限设置了过期时间的键)(volatile-lfu)
  • 策略说明: 从已设置过期时间的键中选择使用频率最低的键进行淘汰。
8. 全部最少使用淘汰 (allkeys-lfu)
  • 策略说明: 当达到内存限制时,移除使用频率最低的键。
9. 无淘汰策略(仅限设置了过期时间的键)(volatile-lru)
  • 策略说明: 如果内存不足以容纳所有数据,并且没有键设置了过期时间,Redis将不执行任何淘汰。
配置淘汰策略
  • 配置方法: 可以通过在 redis.conf 配置文件中设置 maxmemory-policy 选项来配置淘汰策略,或者通过 CONFIG SET maxmemory-policy 命令动态设置。
注意
  • 内存限制: 淘汰策略通常与 maxmemory 配置项一起使用,该配置项用于设置 Redis 最大内存使用量。
  • 持久化: 淘汰策略不影响持久化。即使数据从内存中被淘汰,它们仍然可能被写入磁盘,如果配置了 RDB 或 AOF 持久化的话。
  • 性能: 选择不同的淘汰策略可能会影响 Redis 的性能,因为某些策略(如 LRU 和 LFU)需要记录额外的信息来确定哪些键应该被淘汰。     
  • 17
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值