Redis 提供了多种数据淘汰策略,用于在内存使用达到上限时自动移除一些键值对以释放空间。这些策略可以通过配置 maxmemory-policy
选项来设置。以下是 Redis 支持的数据淘汰策略:
-
noeviction(默认策略):
- 当内存达到限制时,对于写请求返回错误。这适用于那些不能容忍数据丢失的应用场景。
- 对于读取操作和某些特殊的写入命令(如 DEL 和部分 SET 命令),Redis 仍然可以正常处理。
-
allkeys-lru:
- 从所有键中选择最近最少使用的键进行删除。这里的 LRU 是“Least Recently Used”的缩写,即最近最少使用的算法。
-
volatile-lru:
- 仅从设置了过期时间的键中选择最近最少使用的键进行删除。
-
allkeys-random:
- 从所有键中随机选择一些键进行删除。
-
volatile-random:
- 仅从设置了过期时间的键中随机选择一些键进行删除。
-
volatile-ttl:
- 从设置了过期时间的键中选择剩余存活时间最短的键进行删除。这里的 TTL 是“Time To Live”的缩写。
-
allkeys-lfu(自 Redis 4.0 起可用):
- 从所有键中选择访问频率最低的键进行删除。LFU 是“Least Frequently Used”的缩写,即最少频繁使用的算法。
-
volatile-lfu(自 Redis 4.0 起可用):
- 仅从设置了过期时间的键中选择访问频率最低的键进行删除。
每种策略都有其适用的场景,选择哪种策略取决于应用的需求和数据的访问模式。例如,如果应用程序中的数据访问非常不均匀,那么 LRU 或 LFU 策略可能比随机删除更有效;如果数据的时效性很重要,那么基于 TTL 的策略可能是更好的选择。