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

定时删除:

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

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

惰性删除:

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

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

定期删除:

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

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

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

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

相关推荐
zhou周大哥8 小时前
银河麒麟安装mysql
数据库·mysql
无敌的黑星星8 小时前
Spring @Transactional 注解全解析
java·数据库·oracle
Rust研习社8 小时前
Rust + PostgreSQL 极简技术栈应用开发
开发语言·数据库·后端·http·postgresql·rust
子木HAPPY阳VIP8 小时前
信创UOS,Docker 完整操作部署(Dockerfile部署方式)&排错整合
linux·运维·redis·nginx·docker·容器·tomcat
河阿里8 小时前
MyBatis-Plus:MyBatis的进阶开发
数据库·mybatis
白晨并不是很能熬夜8 小时前
【RPC】第 4 篇:服务发现 — Zookeeper + 缓存容错
java·后端·程序人生·缓存·zookeeper·rpc·服务发现
sjsjsbbsbsn8 小时前
向量数据库
数据库
逸Y 仙X8 小时前
文章十六:ElasticSearch 使用enrich策略实现大宽表
java·大数据·数据库·elasticsearch·搜索引擎·全文检索
Sherry Wangs8 小时前
MySQL 与向量数据库的核心区别:从结构化数据到语义搜索
数据库·mysql
@小柯555m8 小时前
MySql(高级操作符--高级操作符练习(2))
数据库·sql·mysql