redis之缓存淘汰策略

1.查看redis的最大占用内存

使用redis-cli命令连接redis服务端,输入命令:config get maxmemory

输出的值为0,0代表redis的最大占用内存等同于服务器的最大内存。

2.设置redis的最大占用内存

编辑redis的配置文件,并重启redis服务

3.生产环境中redis的最大使用内存配置多少?

正常情况下配置为服务器内存的四分之三。

4.如果redis内存满了会出现什么情况

先使用config set maxmwmery 1命令将redis的最大使用内存设置为1字节

需要注意config set maxmwmery命令重启就失效了,想要永久修改,需要编辑redis的配置文件并重启redis服务。

然后执行set命令

当value的值超过redis的最大内存,会抛出OOM异常

5.redis过期键的删除策略

(1)立即删除

对cpu不够友好,用处理器性能换取内存(时间换空间)。

(2)惰性删除

数据达到过期时间,不做处理,等下次访问该数据时,如果未过期,返回数据;发现已过期,删除,返回不存在。

惰性删除没有时效性,可能会造成内存资源的浪费。

惰性删除对内存不够友好,用内存空间换取处理器性能(空间换时间)

redis开启惰性删除配置

(3)定期删除

定期删除策略每隔一段时间执行一次删除过期键操作并通过限制删除操作执行时长和频率来减少删除操作对CPU时间的影响

举例:redis每隔100ms抽取部分key检查是否过期,过期则删除

定期删除就是基于立即删除和惰性删除的折中的一种删除算法

(4)总结

上述的删除策略都有弊端

当使用定期删除时,过期的key可能从来没有被抽到

当使用惰性删除时,过期的key可能从来没有被访问到

这样大量过期的key堆积在内存中,导致redis内存空间紧张

6.redis共有多少种缓存淘汰策略

redis共有8种缓存淘汰策略(详见redis配置文件)

redis默认的删除策略是noeviction>

7.lru和lfu算法的区别是什么

LRU means Least Recently Used(淘汰最长时间没被使用到的)

LFU means Least Frequently Used(淘汰一定时间段内被访问次数最少的)

举例:

8.生产中redis的过期策略使用哪一种

简单地说:当不知道自己的业务场景适合哪一种删除策略时,可以使用allkeys-lru 策略。

9.redis配置淘汰策略

编辑redis配置文件,并重启redis服务

10.redis的淘汰策略什么时候会触发

当Redis设置了最大内存限制(通过 maxmemory 配置项),并且当前使用的内存达到了这个限制,Redis会根据设定的淘汰策略来移除一些键,以便为新的键腾出内存。

相关推荐
来旺2 小时前
互联网大厂Java面试全解析及三轮问答专项
java·数据库·spring boot·安全·缓存·微服务·面试
摇滚侠2 小时前
Spring Boot 3零基础教程,yml文件中配置和类的属性绑定,笔记15
spring boot·redis·笔记
摇滚侠2 小时前
Spring Boot 3零基础教程,WEB 开发 HTTP 缓存机制 笔记29
spring boot·笔记·缓存
cr7xin3 小时前
基于Session和Redis实现短信验证码登录
数据库·redis·缓存
DemonAvenger5 小时前
深入浅出 Redis 布隆过滤器:从原理到实战,10 年经验总结
数据库·redis·性能优化
爬山算法18 小时前
Redis(66)Redis如何实现分布式锁?
数据库·redis·分布式
恋红尘19 小时前
Redis面试八股
数据库·redis·面试
creator_Li19 小时前
缓存行Cache Line
缓存
阿维的博客日记1 天前
Redis学习笔记-QuickList
redis·笔记·学习
机灵猫1 天前
Redis 在订单系统中的实战应用:防重、限流与库存扣减
数据库·redis·缓存