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

相关推荐
番茄你个西红423 分钟前
安装KingbaseES时服务器swap的设置
linux·数据库
是一个Bug30 分钟前
Spring事件监听器源码深度解析
java·数据库·spring
Wang's Blog32 分钟前
MongoDB小课堂: 分片集群架构深度解析与生产级优化指南
数据库·mongodb·架构
万邦科技Lafite39 分钟前
API接口地址解析地区码操作指南
网络·数据库·redis·缓存·开放api·电商开放平台
此生只爱蛋43 分钟前
【Redis】常用命令
数据库·redis·缓存
Zsr10231 小时前
MySQL 主从同步与读写分离:构建高性能、高可用数据库架构
数据库·mysql
老华带你飞1 小时前
房屋租赁管理|基于springboot + vue房屋租赁管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·毕设
踢球的打工仔1 小时前
mysql多表关联
数据库·mysql
少许极端1 小时前
Redis入门指南:从零到分布式缓存(一)
redis·分布式·缓存·微服务
IvorySQL1 小时前
Postgres 18:Skip Scan - 摆脱最左索引限制
数据库·postgresql·开源