redis数据淘汰策略

数据淘汰策略

介绍

当 Redis 的内存达到配置的最大值(maxmemory)时,为了保证新数据能正常写入,Redis 会按照预设的规则,主动删除一部分旧数据,这个规则就是数据淘汰策略。

它和 "过期删除策略" 是两套独立的机制: 过期删除策略:处理已经过期的 key。 数据淘汰策略:在内存不足时,处理所有 key(无论是否过期)。

二、Redis 支持的 8 种淘汰策略

Redis 提供了 8 种淘汰策略,可分为四大类:

1. 默认策略(不淘汰)
  • noeviction(默认):不淘汰任何 key,当内存满时,拒绝所有新的写入操作并返回错误。

    适合对数据完整性要求极高、不允许丢失任何数据的场景。

2. 基于 TTL 的策略
  • volatile-ttl :仅对设置了过期时间(TTL)的 key,优先淘汰剩余 TTL 最短的 key。

  • volatile-random:仅对设置了过期时间的 key,随机淘汰。

  • volatile-lru:仅对设置了过期时间的 key,使用 LRU(最近最少使用)算法淘汰。

  • volatile-lfu:仅对设置了过期时间的 key,使用 LFU(最少频率使用)算法淘汰。

3. 针对所有 key 的策略
  • allkeys-random:对所有 key,随机淘汰。

  • allkeys-lru:对所有 key,使用 LRU 算法淘汰最近最少使用的 key。

  • allkeys-lfu:对所有 key,使用 LFU 算法淘汰访问频率最低的 key。

三、核心算法:LRU vs LFU

  • LRU(Least Recently Used,最近最少使用)

    1)用当前时间减去最后一次访问时间,值越大的key淘汰优先级越高。

    2)适合场景:热点数据相对稳定,最近访问的就是最有价值的。

  • LFU(Least Frequently Used,最少频率使用)

    1)会统计每个key的访问频率,值越小淘汰优先级越高。

    2)适合场景:存在短时高频访问的场景,比如秒杀活动。

四、建议

优先选择 allkeys-lru:这是最通用的策略,能自动保留最近最常访问的热点数据,适合大多数有明显冷热数据区分的业务场景。

数据访问频率无明显差异 :选择 allkeys-random

需要保留 "置顶" 数据 :选择 volatile-lru,并给 "置顶" 数据不设置过期时间,这样它们永远不会被淘汰。

存在短时高频访问场景 :选择 allkeys-lfuvolatile-lfu,能更好地保留访问频率高的数据。

  1. 问:数据库有 1000 万数据,Redis 只能缓存 20 万,如何保证 Redis 中都是热点数据?

    答:使用 allkeys-lru

  2. 问:Redis 内存用完了会发生什么?

    答:这取决于配置的淘汰策略。如果是默认的 noeviction,Redis 会拒绝所有新的写入操作并返回错误;如果是其他策略,Redis 会按规则淘汰旧数据,为新数据腾出空间。

相关推荐
予枫的编程笔记1 分钟前
【Kafka进阶篇】Canal+Kafka+ES实战:内容平台数据同步难题,这样解最优雅
redis·mysql·elasticsearch·kafka·canal·数据同步·异步解耦
LSL666_1 分钟前
5 Redis通用命令
java·开发语言·redis·命令
rannn_1113 分钟前
【Redis|基础篇】初识、Redis的安装与启动、Redis命令、Java客户端
java·redis·后端·缓存·nosql
FakeOccupational11 分钟前
【有趣项目 Windows】浏览器缓存读取应用 chromecacheview 数据恢复+数字取证+调试网页
缓存
西门吹雪分身35 分钟前
SpringCloudGateway过滤器之RequestRateLimiterGatewayFilterFactory
java·redis·spring cloud
羑悻的小杀马特1 小时前
LFU缓存算法全解:从双哈希+双向链表到O(1)艺术,解锁长期热点守护神
算法·缓存·哈希算法·lfu·双链表
難釋懷1 小时前
基于Redis的Stream结构作为消息队列,实现异步秒杀下单
数据库·redis·缓存
七夜zippoe1 小时前
微服务架构下Spring Session与Redis分布式会话实战全解析
java·redis·maven·spring session·分布式会话
期待のcode11 小时前
SpringBoot连接Redis
spring boot·redis·后端