Redis过期数据的删除策略是什么?有哪些?

定时删除:

  • 每个设置了TTL的key中都会创建一个计时器,等到过期时间就会立即删除

  • 对内存友好,但是会占用大量的CPU资源去处理过期数据,从而影响缓存的吞吐量和响应时间

惰性删除:

  • 设置了key的过期后,不会立即删除,而是当我们访问的时候,会检查该key是否已过期,如果过期则删除,没有过期则继续使用

  • 对可以最大化地节省CPI资源,但是十分消耗内存,在极端情况下,可能会出翔大量的过期key没有被再次访问,从而一直存在内存中没有被释放

定期删除:

  • 每隔一段时间,扫描一定数量的数据库的expires字典中一定数量的随机key,删除其中已过期的数据

  • 可以通过限制删除操作执行的时长和频率来减少删除操作对CPU影响

  • slow模式,执行频率默认为10hz,每次不超过25ms

  • fast模式:执行频率不固定,两次间隔不低于2ms,每次耗时不超过1ms

相关推荐
施嘉伟1 小时前
一次生产环境 SQL 不走索引的排查过程
数据库·sql
踏浪无痕1 小时前
SQLInsight:从JDBC底层到API调用的零侵入SQL监控方案
数据库·后端·开源
小宇的天下2 小时前
Calibre nmDRC Results(19-1)
服务器·数据库·oracle
Web项目开发2 小时前
Mysql创建索引的SQL脚本,复制粘贴即可使用
数据库·sql·mysql
晴天¥3 小时前
Oracle如何在DBeaver上进行登录
数据库·oracle
2301_800256113 小时前
事务处理-同步与调度-两阶段锁-隔离级别
数据库·oracle
小罗和阿泽3 小时前
MySql数据库系列 数据库基础操作
数据库·mysql
周末吃鱼3 小时前
mysql8.0支持CURRENT_DATE如何写
数据库·sql·mysql
kaico20184 小时前
MySQL的窗口函数
数据库·mysql
luming-024 小时前
报错解决:IDEA终端输出和CMD终端输出Maven版本不一致
java·缓存·bug·intellij-idea