Redis驱逐策略简介

Redis驱逐策略

要说到Redis的驱逐策略,可以通过在配置文件redis.conf中使用maxmemory和maxmemory-policy两个参数进行配置。

其中maxmemory用于指定最大的存储内存数。例如

maxmemory 100mb

如果将这个参数设置为0则表示不限制内存。

maxmemory-policy有以下几个选项

  • noeviction

不驱逐,直接返回错误。

  • allkeys-lru

对所有的key,使用lru(least recently used)策略。redis为了提升性能,并不会真的从所有key中找到全局最小值的进行淘汰,而是通过采样获取近似值的方式来决定最近使用的key。采样数可以通过maxmemory-samples 参数进行配置。

maxmemory-samples 3

  • volatile-lru

对已经设置了ttl的key,使用lru(least recently used)策略。这个也是采样近似值。通过maxmemory-samples参数控制采样数。

  • allkeys-random

对所有key,随机进行驱逐。

  • volatile-random

对设置了ttl的key,随机进行驱逐。

  • volatile-ttl

volatile-ttl的作用,是从设置了ttl的key中,选择最接近过期时间的key进行淘汰。这个也是采样近似值。通过maxmemory-samples参数控制采样数。

该值默认为3,可以通过配置这个值来提高最小ttl的获取精度。

  • allkeys-lfu (redis 4.0以上)

对所有key使用lfu(least frequently used)策略。这个也是采样近似值。通过maxmemory-samples参数控制采样数。

  • volatile-lfu(redis 4.0以上)

对设置了ttl的key,使用lfu(least frequently used)策略。这个也是采样近似值。通过maxmemory-samples参数控制采样数。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值