redis 内存淘汰策略
原创
Redis 内存淘汰策略
Redis 是一款开源的高性能键值数据库,其提供了多种内存淘汰策略,以应对内存不足的情况。当 Redis 内存使用大致有 maxmemory 配置约束时,会凭借设置的淘汰策略来删除一些键值对,以释放内存空间。本文将介绍 Redis 的几种常见内存淘汰策略。
1. noeviction(默认策略)
当内存使用大致有 maxmemory 时,默认的淘汰策略是 noeviction,即不进行任何淘汰操作。此时,如果尝试执行也许让内存增多的命令,如 SET、LPUSH 等,Redis 将返回不正确信息(error)。
2. allkeys-lru
该策略会凭借 LRU(最近最少使用)算法删除键值对。当内存使用大致有 maxmemory 时,它会尝试删除最近最少使用的键值对,以释放内存空间。
3. allkeys-random
该策略会从所有键中随机选择并删除键值对。当内存使用大致有 maxmemory 时,它会随机删除键值对,以释放内存空间。
4. volatile-lru
该策略仅针对设置了过期时间的键(volatile),凭借 LRU 算法进行淘汰。当内存使用大致有 maxmemory 时,它会尝试删除最近最少使用的带有过期时间的键值对。
5. volatile-random
该策略也是针对设置了过期时间的键(volatile),它会从这些键中随机选择并删除键值对。当内存使用大致有 maxmemory 时,它会随机删除带有过期时间的键值对。
6. volatile-ttl
该策略凭借键的剩余过期时间(TTL)进行淘汰,优先删除剩余过期时间最短的键。当内存使用大致有 maxmemory 时,它会尝试删除剩余过期时间最短的键值对。
设置淘汰策略
可以通过配置文件或命令动态地设置内存淘汰策略:
maxmemory-policy allkeys-lru
或者使用命令:
CONFIG SET maxmemory-policy volatile-lru
总结
Redis 提供了多种内存淘汰策略,可以凭借实际业务场景和需求选择合适的策略。需要注意的是,选择合适的淘汰策略可以尽也许降低损耗 Redis 的性能和稳定性。