Redis 的6种回收策略(淘汰策略)详解

Redis 的6种回收策略(淘汰策略)详解

  • 1、Redis的六种淘汰策略
    • [1. volatile-lru](#1. volatile-lru)
    • [2. volatile-ttl](#2. volatile-ttl)
    • [3. volatile-random](#3. volatile-random)
    • [4. allkeys-lru](#4. allkeys-lru)
    • [5. allkeys-random](#5. allkeys-random)
    • [6. no-eviction](#6. no-eviction)
  • 2、使用策略规则

|-----------------------------|
| 💖The Begin💖点点关注,收藏不迷路💖 |

在Redis中,当内存使用达到上限时,为了保持服务的稳定性和响应速度,Redis提供了多种数据回收(淘汰)策略,以便在必要时释放内存空间。本文将详细介绍Redis的六种主要淘汰策略。

1、Redis的六种淘汰策略

1. volatile-lru

  • 说明 :从已设置过期时间的数据集(server.db[i].expires)中挑选最近最少使用的数据进行淘汰。
  • 适用场景:适用于数据访问频率差异较大的场景,即部分数据访问频繁,部分数据访问较少。

2. volatile-ttl

  • 说明:从已设置过期时间的数据集中挑选那些即将过期的数据进行淘汰。
  • 适用场景:当希望优先淘汰那些即将过期的数据时,可以使用此策略。

3. volatile-random

  • 说明:从已设置过期时间的数据集中随机选择数据进行淘汰。
  • 适用场景:当数据集的访问频率没有明显差异,且希望随机淘汰过期数据时,此策略是一个不错的选择。

4. allkeys-lru

  • 说明 :从所有数据集(server.db[i].dict)中挑选最近最少使用的数据进行淘汰,不局限于已设置过期时间的数据。
  • 适用场景:如果数据访问频率呈现出幂律分布(即大部分数据访问频率低,少数数据访问频率高),此策略非常有效。

5. allkeys-random

  • 说明:从所有数据集中随机选择数据进行淘汰。
  • 适用场景:当数据集的访问频率几乎相同时,可以使用此策略。然而,由于Redis的设计初衷是快速存取,因此这种策略在实际应用中并不常见。

6. no-eviction

  • 说明:不进行任何淘汰操作,当内存不足时,Redis会拒绝新的写入请求,并返回错误。
  • 适用场景:在某些特定的场景下,如不希望因淘汰数据而影响业务逻辑时,可以使用此策略。但需要注意的是,这可能会导致Redis服务拒绝新的写入请求。

2、使用策略规则

  • 幂律分布场景 :如果数据访问频率呈现出幂律分布,即大部分数据访问频率低,少数数据访问频率高,推荐使用allkeys-lru策略。这可以确保那些长时间未被访问的数据被优先淘汰,从而为新的热点数据腾出空间。

  • 平等分布场景 :如果数据集的访问频率几乎相同,即所有数据的访问频率都相似,那么可以考虑使用allkeys-random策略。然而,在实际应用中,这种情况较为少见,因为大多数业务场景下的数据访问都会存在一定的差异。

|---------------------------|
| 💖The End💖点点关注,收藏不迷路💖 |

相关推荐
努力学算法的蒟蒻几秒前
day70(1.29)——leetcode面试经典150
算法·leetcode·面试
l1t5 分钟前
在Windows的WSL中试用GizmoSQL UI连接GizmoSQL数据库服务器
数据库·windows·ui
2301_811232989 分钟前
使用Python进行PDF文件的处理与操作
jvm·数据库·python
梦想的旅途210 分钟前
企微全自动化运营的可视化与度量
数据库·mysql
jiunian_cn13 分钟前
【Redis】string数据类型相关指令
数据库·redis·缓存
无限码力14 分钟前
华为OD技术面真题 - 数据库MySQL - 2
数据库·华为od·华为od技术面真题·华为od技术面八股·华为od面试八股文·华为od技术面mysql问题
只是懒得想了14 分钟前
Go语言ORM深度解析:GORM、XORM与entgo实战对比及最佳实践
开发语言·数据库·后端·golang
半熟的皮皮虾15 分钟前
Excel2SQL的自动转SQL工具功能升级
数据库·sql·信息可视化
掘根16 分钟前
【jsonRpc项目】Registry-Discovery模块
运维·服务器·数据库
fly啊16 分钟前
深度解析:146. LRU 缓存(哈希表 + 双向链表的艺术)
链表·缓存·散列表