Redis的内存淘汰策略

Redis 作为一个内存数据库,提供了多种内存淘汰策略,以便在内存使用达到限制时管理数据的存储。内存淘汰策略决定了在 Redis 的内存达到限制时,应该清除哪些数据。以下是 Redis 支持的主要内存淘汰策略:

1. 限制内存的配置

在介绍淘汰策略之前,需要先配置 Redis 的最大内存限制。可以在 redis.conf 文件中设置 maxmemory 参数,或者在运行时使用 CONFIG SET maxmemory 命令。

2. 淘汰策略

Redis 提供了以下几种内存淘汰策略,使用 maxmemory-policy 配置选项进行设置:

  1. noeviction

    • 不淘汰任何键,当内存达到限制时,所有写入操作(如 SETLPUSH 等)将返回错误。这是默认行为。
  2. allkeys-lru(最近最少使用):

    • Redis 将在所有的键中,淘汰最近最少使用的键。当内存达到限制时,此策略将删除最少使用的键以腾出空间。
  3. volatile-lru(最近最少使用,仅限于设置过过期时间的键):

    • 仅淘汰那些设置了过期时间的键,并使用 LRU 策略,即淘汰最近最少使用的过期键。
  4. allkeys-random(随机淘汰):

    • 随机移除一些键,无论这些键是否设置了过期时间。这提供了一种简单的替代方案,避免了最少使用的计算开销。
  5. volatile-random(随机淘汰,仅限于设置过过期时间的键):

    • 随机删除一部分设置了过期时间的键。
  6. volatile-lfu(最近最不常用,仅限于设置过期时间的键):

    • 淘汰策略基于 LFU(Least Frequently Used)算法,仅限于设置了过期时间的键。
  7. allkeys-lfu(最近最不常用):

    • 淘汰所有键中的 LFU 键,无论这些键是否设置了过期时间。
相关推荐
笃行35014 小时前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行35015 小时前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行35015 小时前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
leeyi20 小时前
Checkpoint 机制:Agent 怎么在断电后接着跑
redis·aigc·agent
SelectDB2 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶2 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵2 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
Nturmoils2 天前
WHERE 条件别凭习惯写,常用查询先跑一遍
数据库
云技纵横2 天前
一个 @Async 让循环依赖暴雷:Spring 代理的暗坑
redis