Redis的数据淘汰策略了解吗?

面试官:Redis数据淘汰策略了解吗?

我: 知道。嗯~~ **当Redis中的内存不够用时,此时再向Redis中添加新的key,Redis就会按照某种规则将内存中的数据删除掉。**这种数据的删除规则被称为内存的淘汰策略。

面试官:能详细说说吗?

我: Redis中提供了很多种,默认是noeviction,即不删除任何数据,内存不足直接报错。

具体用哪种策略,在redis.conf配置文件中可设置。

有两个很重要的概念。LRU(Least Recently Used)和LFU(Least Frequently Used)。

LRU意思是最少最近使用,用当前时间减去最后一次访问时间,这个值越大则淘汰优先级越高。

LFU是最少频率使用。会统计每个key的访问频率,频率越小,淘汰优先级越高。

我们在项目中设置的是allkeys-lru,即挑选最近最少使用的数据淘汰,留下经常访问的热点数据在redis中。

面试官:如果数据库有1000万数据,Redis只能缓存20w数据,如何保证Redis中的数据都是热点数据?

我:使用allkeys-lru,将最近最少使用的数据淘汰掉,留下的就是经常访问的数据了。

面试官:Redis的内存用完了会怎样?

我:这取决于设置了哪种数据淘汰策略,如果是默认的话noeviction,直接会报错。

附:

Redis内存的8种淘汰策略:

相关推荐
聆风吟º21 小时前
Oracle到KingbaseES数据库迁移:全流程实战指南与避坑总结
数据库·oracle·数据库迁移·kingbasees
哈__21 小时前
Oracle至KingbaseES数据库迁移全攻略:痛点拆解、配置实操与问题排查
数据库·oracle
JZC_xiaozhong21 小时前
电商ERP如何同步订单数据到MySQL?集成方案解析
数据库·mysql·数据分析·etl工程师·嵌入式实时数据库·电商erp集成·数据集成与应用集成
消失的旧时光-194321 小时前
第四篇(实战): 订单表索引设计实战:从慢 SQL 到毫秒级
java·数据库·sql
知识分享小能手1 天前
Oracle 19c入门学习教程,从入门到精通, Oracle 表空间与数据文件管理详解(9)
数据库·学习·oracle
zhengfei6111 天前
Chroma DB — 未经授权的信息披露
数据库
KaiwuDB1 天前
KaiwuDB 获评“2025 中国大数据产业年度国产化优秀代表厂商”
数据库
百***07451 天前
一步API+Gemini 3.0 Pro进阶实战:多模态开发、性能调优与项目落地
数据库·microsoft
不想写bug呀1 天前
Redis主从复制介绍
数据库·redis
颜颜yan_1 天前
Oracle 迁移到 KingbaseES 实战:从评估到追平的一套可落地流程
数据库·oracle