Redis 中有哪些内存淘汰策略?
Redis 中有哪些内存淘汰策略?
回答重点
Redis 的内存淘汰策略一共有 8 种。 8 种里面可以细分为两大类,即开启数据淘汰和不开启数据淘汰两大类,然后开启数据的那一类又可以进行细分,分为基于过期时间的淘汰策略以及全部数据的淘汰策略。
不淘汰数据(默认):
- noeviction:当运行内存超过最大设置内存的时候,不会淘汰数据,而是直接返回报错禁止写入
设置了过期时间的数据淘汰:
- volatile-random:随机淘汰掉设置了过期时间的 key
- volatile-ttl:优先淘汰掉较早过期的 key
- volatile-lru(redis3.0之前默认策略):淘汰掉所有设置了过期时间的,然后最久未使用的 key
- volatile-lfu(redis4.0后新增):与上面类似,不过是淘汰掉最少使用的 key
所有数据的数据淘汰:
- allkeys-random:随机淘汰掉任意的 key
- allkeys-lru:淘汰掉缓存中最久没有使用的 key
- allkeys-lfu(redis4.0后新增):淘汰掉缓存中最少使用的 key
扩展知识
不同淘汰策略适用场景
noeviction:适用于所有数据都被持久化或避免丢失任何数据的场景。allkeys-lru:适用于希望保证最常访问的数据在内存中的场景。如电商促销活动中,某些商品会在短时间内被频繁访问,此时不会被淘汰。allkeys-lfu:适用于希望保证访问频率最高的数据在内存中的场景。如社交媒体或直播类应用中,某些热点内容访问次数高,不能被淘汰。allkeys-random:适用于对数据没有严格的优先级需求。volatile-lru:同allkeys-lru,仅只关心设置了过期时间的键。volatile-random:同allkeys-random,仅只关心设置了过期时间的键。volatile-ttl:适用于对实时性较敏感的场景,比如存储用户会话等。volatile-lfu:同allkeys-lfu,仅只关心设置了过期时间的键。
noeviction 演示
通过 config set maxmeory 先将其内存大小修改至 2 字节,然后设置一个超过 2 字节的字符串值 99999,其会报一个 OOM 的错误,并且不允许写入。
不过需要注意一个点,虽然其不支持写入数据,但是已有的数据并不会删除,其还是可以进行查询和删除操作,如下图所示,这里演示了 keys * 指令,发现其执行结果正常。
这里补充一个知识点,如果不设置最大内存大小或者设置最大内存大小为 0 的话,在 64 位操作系统下不限制内存大小,在 32 位操作系统下最多使用 3 GB 内存。
内存淘汰配置
可以通过修改 Redis 配置文件(redis.conf)中的 maxmemory-policy 参数来设置不同的内存淘汰策略(配置后需要重启 redis,且后续重启后配置不会丢失)。
例如:
1 | maxmemory-policy allkeys-lru |
或者通过 Redis 命令动态设置(立即生效,不需要重启,但是重启后就失效了):
1 | CONFIG SET maxmemory-policy allkeys-lru |
Comments