Day07:缓存-数据淘汰策略

Redis的数据淘汰策略有哪些 ? (key过期导致的)

在redis中提供了两种数据过期删除策略

第一种是惰性删除,在设置该key过期时间后,我们不去管它,当需要该key时,我们再检查其是否过期,如果过期,我们就删掉它,反之返回该key。

优点:对CPU友好,只有使用该key时才会进行过期检查,对于很多用不到的key不用浪费时间进行过期检查。

缺点:对内存不友好,如果一个key已经过期,但是一直没有使用,那么该key会一直存在内存中。

第二种是 定期删除 ,就是说每隔一段时间,我们就对一些key进行检查,删除里面过期的key(每次检查一定量的key,随着时间的推移会遍历一遍redis中所有的key,直到都检查一遍。可以确保,假如一个key过期了,一定会被删除)。

定期清理的两种模式:

  • SLOW模式是定时任务,执行频率默认为10hz,每次不超过25ms,设置这么短的清理时间是为了尽量少的占用主进程操作,可以通过修改配置文件redis.conf 的 hz 选项来调整这个次数。
  • FAST模式执行频率不固定,每次事件循环会尝试执行,但两次间隔不低于2ms,每次耗时不超过1ms。

定期删除的优点:可以通过限制删除操作执行的时长和频率来减少删除操作对CPU的影响。另外定期删除也能有效释放过期键占用的内存。

缺点:难以确定删除操作执行的时长和频率。

Redis的过期删除策略:惰性删除 + 定期删除 两种策略进行配合使用

相关推荐
zizisuo11 小时前
6.1.多级缓存架构
缓存·架构
JavaGuide13 小时前
腾讯Java后端一面,被速通了!
网络·http·缓存·程序员·idea·多线程·校招·java基础·并发编程·aio·计算机基础·认证授权
南隅。14 小时前
【Redis】基础2:作为缓存
redis·缓存
TE-茶叶蛋15 小时前
Redis 原子操作
数据库·redis·缓存
我科绝伦(Huanhuan Zhou)18 小时前
Nginx性能优化:从配置到缓存,全面提升Web服务器性能
nginx·缓存·性能优化
星星点点洲1 天前
【缓存与数据库结合最终方案】伪从技术
数据库·缓存
Ivan陈哈哈1 天前
Redis是单线程的,如何提高多核CPU的利用率?
数据库·redis·缓存
头顶秃成一缕光1 天前
Redis的主从模式和哨兵模式
数据库·redis·缓存
观无1 天前
Redis安装及入门应用
数据库·redis·缓存
XY.散人1 天前
初识Redis · 哨兵机制
数据库·redis·缓存