Redis 的缓存淘汰策略

Redis 作为一个高性能的内存数据库,提供了多种缓存淘汰策略(也称为过期策略或驱逐策略),用于管理内存使用。当 Redis 达到其内存限制时,系统会根据配置的策略删除一些数据,以释放内存空间。以下是 Redis 支持的几种主要缓存淘汰策略:

  1. noeviction: 当内存不足以容纳新写入数据时,新写入操作会报错。这种策略适用于不能丢失任何数据的场景。

  2. allkeys-lru: 从所有键中选择最近最少使用(Least Recently Used, LRU)的键进行淘汰。这是一个常用的策略,适用于大多数缓存场景。

  3. volatile-lru: 从设置了过期时间的键中选择最近最少使用(Least Recently Used, LRU)的键进行淘汰。适用于只淘汰那些有过期时间的键。

  4. allkeys-random: 从所有键中随机选择键进行淘汰。适用于对键的使用频率没有特别要求的场景。

  5. volatile-random: 从设置了过期时间的键中随机选择键进行淘汰。适用于只淘汰那些有过期时间的键,且不关心键的使用频率。

  6. volatile-ttl: 从设置了过期时间的键中选择存活时间最短(Time to Live, TTL)的键进行淘汰。优先淘汰即将过期的键。

  7. allkeys-lfu: 从所有键中选择最少使用频率(Least Frequently Used, LFU)的键进行淘汰。这种策略适用于那些有些键被频繁访问,而有些键很少被访问的场景。

  8. volatile-lfu: 从设置了过期时间的键中选择最少使用频率(Least Frequently Used, LFU)的键进行淘汰。适用于只淘汰那些有过期时间的键,且有些键被频繁访问,而有些键很少被访问的场景。

这些策略可以通过 Redis 配置文件或运行时命令进行设置。例如,可以在 Redis 配置文件(redis.conf)中设置:

conf 复制代码
maxmemory-policy allkeys-lru

或者通过运行时命令进行设置:

shell 复制代码
CONFIG SET maxmemory-policy allkeys-lru

选择合适的淘汰策略可以根据具体应用场景的需求,数据访问模式和内存使用情况来决定。

相关推荐
闪电悠米12 小时前
黑马点评-Redis ZSet-实现关注 Feed 流
服务器·网络·数据库·redis·缓存·junit·lua
Devin~Y12 小时前
大厂 Java 面试实录:从音视频内容社区到 AI RAG 的全链路技术设计
java·spring boot·redis·spring cloud·微服务·kafka·音视频
小小工匠12 小时前
Redis - 主从集群脑裂:数据丢失的隐藏杀手
数据库·redis
不能只会打代码1 天前
边缘视频分析平台的架构设计与性能优化——从750ms到190ms的调优之路
java·spring boot·redis·性能优化·边缘计算·物联网竞赛
xufengzhu1 天前
第三方 Python 库 redis-py + hiredis 的使用
开发语言·redis·python
轻刀快马1 天前
跨越软硬件的共鸣(二):从 Cache 写策略看 Redis 与 DB 的一致性博弈
java·开发语言·redis·计算机组成原理
lazy H1 天前
Spring Boot 项目如何连接 Redis?新手入门配置和常见错误总结
ide·spring boot·redis·后端·学习·intellij-idea
木雷坞1 天前
Firecrawl Docker Compose 自托管排查:镜像、Redis、队列和 Playwright
redis·docker·容器·firecrawl
柏舟飞流1 天前
Spring Boot 进阶实战:整合 MyBatis、Redis、JWT,搭一个更像真实项目的后端服务
spring boot·redis·mybatis
南部余额1 天前
Canal解决MySQL与Redis数据一致性问题
数据库·redis·mysql·canal·数据·数据同步