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种淘汰策略:

相关推荐
KaMeidebaby1 分钟前
卡梅德生物技术快报|基因测序技术在 46,XY 性发育障碍变异筛查中的流程与数据分析
服务器·前端·数据库·人工智能·算法·数据挖掘·数据分析
AI周红伟9 分钟前
长鑫科技存储之王:存储三强对比:三星、SK海力士 vs 长鑫科技
数据库·人工智能·科技·react.js·架构·langchain
灰阳阳19 分钟前
MySQL-Innodb-表空间数据组织方式
数据库·mysql·innodb
计算机安禾25 分钟前
【算法设计与分析】第29篇:启发式与元启发式搜索方法综述
java·数据库·算法
DIY源码阁26 分钟前
JavaSwing学生选课系统 - MySQL版
java·数据库·mysql·eclipse
城管不管34 分钟前
Agent——001
android·java·数据库·llm·prompt
AC赳赳老秦35 分钟前
OpenClaw批量任务队列优化:解决任务堆积、执行缓慢、优先级混乱问题
java·大数据·数据库·c++·自动化·php·openclaw
J2虾虾41 分钟前
Spring AI Alibaba - 工作流(Workflow)
数据库·人工智能·spring
辞忧九千七41 分钟前
Redis 哨兵(Sentinel)模式部署教程(基于一主二从架构)
redis·架构·sentinel
TDengine (老段)44 分钟前
TDengine Compaction 合并策略 — STT 整理、文件合并与后台调度
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据