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

相关推荐
KELLENSHAW24 分钟前
MySQL45讲 第三十七讲 什么时候会使用内部临时表?——阅读总结
数据库·mysql
weisian1511 小时前
Redis篇--常见问题篇7--缓存一致性2(分布式事务框架Seata)
redis·分布式·缓存
白云coy1 小时前
Redis 安装部署[主从、哨兵、集群](linux版)
linux·redis
Logintern091 小时前
Linux如何设置redis可以外网访问—执行使用指定配置文件启动redis
linux·运维·redis
小刘鸭!2 小时前
Hbase的特点、特性
大数据·数据库·hbase
凡人的AI工具箱2 小时前
每天40分玩转Django:Django表单集
开发语言·数据库·后端·python·缓存·django
奔跑草-2 小时前
【数据库】SQL应该如何针对数据倾斜问题进行优化
数据库·后端·sql·ubuntu
快乐非自愿2 小时前
.NET 9 中的 多级缓存 HybridCache
缓存·.net
Elastic 中国社区官方博客2 小时前
如何通过 Kafka 将数据导入 Elasticsearch
大数据·数据库·分布式·elasticsearch·搜索引擎·kafka·全文检索
P.H. Infinity2 小时前
【Redis】配置序列化器
数据库·redis·缓存