redis的淘汰策略

Redis 的淘汰策略(Eviction Policy)是指当 Redis 内存不足时,如何选择删除哪些数据来腾出空间。以下是 Redis 支持的几种淘汰策略,用通俗的话解释它们的特点:


1. noeviction(不淘汰)

  • 特点

    • 当内存不足时,新写入的数据会报错,旧数据不会被删除。
  • 适用场景

    • 数据非常重要,绝对不能丢失。
  • 通俗解释

    • "内存满了?那就别写新数据了,直接报错!"

2. allkeys-lru(最近最少使用)

  • 特点

    • 从所有 Key 中,删除最近最少使用的 Key。
  • 适用场景

    • 适合大多数场景,优先保留最近常用的数据。
  • 通俗解释

    • "谁最近没用过,就把谁踢出去!"

3. volatile-lru(最近最少使用,仅限过期 Key)

  • 特点

    • 从设置了过期时间的 Key 中,删除最近最少使用的 Key。
  • 适用场景

    • 只淘汰那些可能会过期的数据,保留永久数据。
  • 通俗解释

    • "只踢那些可能会过期的,而且最近没用的!"

4. allkeys-random(随机淘汰)

  • 特点

    • 从所有 Key 中,随机删除一个 Key。
  • 适用场景

    • 数据没有明显的访问模式,随机淘汰即可。
  • 通俗解释

    • "随便踢一个,看谁倒霉!"

5. volatile-random(随机淘汰,仅限过期 Key)

  • 特点

    • 从设置了过期时间的 Key 中,随机删除一个 Key。
  • 适用场景

    • 只淘汰那些可能会过期的数据,随机选择。
  • 通俗解释

    • "只踢那些可能会过期的,随便踢一个!"

6. volatile-ttl(最短存活时间)

  • 特点

    • 从设置了过期时间的 Key 中,删除剩余存活时间最短的 Key。
  • 适用场景

    • 优先淘汰即将过期的数据。
  • 通俗解释

    • "谁快过期了,就先踢谁!"

7. allkeys-lfu(最少频率使用)

  • 特点

    • 从所有 Key 中,删除访问频率最低的 Key。
  • 适用场景

    • 适合访问频率有明显差异的场景。
  • 通俗解释

    • "谁用得最少,就把谁踢出去!"

8. volatile-lfu(最少频率使用,仅限过期 Key)

  • 特点

    • 从设置了过期时间的 Key 中,删除访问频率最低的 Key。
  • 适用场景

    • 只淘汰那些可能会过期的数据,优先淘汰访问频率低的。
  • 通俗解释

    • "只踢那些可能会过期的,而且用得最少的!"

9. 总结

策略名称 特点 通俗解释
noeviction 内存不足时,新写入数据报错,不删除旧数据 "内存满了?直接报错!"
allkeys-lru 删除最近最少使用的 Key "谁最近没用过,就把谁踢出去!"
volatile-lru 删除设置了过期时间的 Key 中,最近最少使用的 Key "只踢那些可能会过期的,而且最近没用的!"
allkeys-random 随机删除一个 Key "随便踢一个,看谁倒霉!"
volatile-random 随机删除一个设置了过期时间的 Key "只踢那些可能会过期的,随便踢一个!"
volatile-ttl 删除设置了过期时间的 Key 中,剩余存活时间最短的 Key "谁快过期了,就先踢谁!"
allkeys-lfu 删除访问频率最低的 Key "谁用得最少,就把谁踢出去!"
volatile-lfu 删除设置了过期时间的 Key 中,访问频率最低的 Key "只踢那些可能会过期的,而且用得最少的!"

10. 如何选择淘汰策略?

  • 如果数据非常重要,不能丢失,选择 noeviction

  • 如果数据有明确的访问模式,选择 LRULFU

  • 如果数据没有明显的访问模式,选择 random

  • 如果数据有过期时间,选择 volatile 相关的策略。

相关推荐
倔强的石头_1 分钟前
深度解析:数据库内核如何通过逻辑推理与常值推导突破去重性能瓶颈
数据库
做个文艺程序员2 分钟前
第02篇:搭建 ES 集群 + Spring Boot 整合实战——从 Docker Compose 到 Java 客户端全覆盖
java·spring boot·elasticsearch
devilnumber2 分钟前
MySQL 部门表:树结构 (自关联) vs 非树结构 (扁平化 / 冗余字段)
数据库·mysql
Jinkxs3 分钟前
LoadBalancer- 简单限流策略:Nginx 基于连接 / 请求的限流实现
java·运维·nginx
fenglllle10 分钟前
JDK8升级JDK17使用CompletableFuture在线程中classloader的变化
java·开发语言·jvm
计算机安禾11 分钟前
【c++面向对象编程】第44篇:typename与class的区别,依赖类型名与template消除歧义
java·jvm·c++
fengxin_rou16 分钟前
【MySQL 三大日志深度解析】:redo log、undo log、binlog 作用与两阶段提交原理
数据库·mysql·日志·redo log
ECT-OS-JiuHuaShan16 分钟前
存在是微分张量积,标量是参数但不可能是本质。还原论泛化,是语义劫持和以偏概全的逻辑谋杀伪科学庞氏骗局
数据库·人工智能·算法·机器学习·数学建模
JAVA面经实录91720 分钟前
Java+SpringAI企业级实战项目完整官方文档(生产终版)
java·开发语言·spring·ai编程
梵得儿SHI20 分钟前
Java IO 流进阶:Buffer 与 Channel 核心概念解析及与传统 IO 的本质区别
java·开发语言·高并发·nio·channel·buffer·提升io效率