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

定时删除:

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

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

惰性删除:

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

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

定期删除:

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

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

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

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

相关推荐
柏油15 分钟前
MySQL 字符集 utf8 与 utf8mb4
数据库·后端·mysql
我科绝伦(Huanhuan Zhou)24 分钟前
异构数据库兼容力测评:KingbaseES 与 MySQL 的语法・功能・性能全场景验证解析
数据库·mysql
Apple_羊先森26 分钟前
Oracle数据库操作深入研究:备份、数据删除与性能优化
数据库·oracle·性能优化
AAA修煤气灶刘哥30 分钟前
搞定 Redis 不难:从安装到实战的保姆级教程
java·redis·后端
青鱼入云39 分钟前
redis怎么做rehash的
redis·缓存
FFF-X1 小时前
Vue3 路由缓存实战:从基础到进阶的完整指南
vue.js·spring boot·缓存
考虑考虑2 小时前
Redis事务
redis·后端
陈天cjq9 小时前
Redis 实用型限流与延时队列:从 Lua 固定/滑动窗口到 Streams 消费组(含脚本与压测)
redis·junit·lua
Warren989 小时前
Lua 脚本在 Redis 中的应用
java·前端·网络·vue.js·redis·junit·lua
xiao-xiang10 小时前
redis-保姆级配置详解
数据库·redis