Redis数据删除策略(惰性删除+定期删除)

文章目录

  • Redis数据删除策略
  • [1. 惰性删除](#1. 惰性删除)
  • [2. 定期删除](#2. 定期删除)
  • [3. Redis过期删除策略用的哪种?](#3. Redis过期删除策略用的哪种?)

Redis数据删除策略

1. 惰性删除

设置key过期时间后,不管它,需要用该key时,再检查是否过期,过期就删掉她,没过期返回

shell 复制代码
set name zhangsan 20

# 发现name过期,直接删除该keyname
get name
  • 优点:对CPU友好,对很多不用的key不用浪费时间进行过期检查
  • 缺点:对内存不友好,如果一个key已经过期,但是一直没有被使用,那么该key就会一直存在内存中,内存永远得不到释放

2. 定期删除

每隔一段时间,对一些key进行检查,删除里面过期的key。检查的这些key是随机的

定期清理有2种模式:

  • SLOW模式:定时任务,执行频率默认10hz(每秒10次),每次不超过25ms。可在redis.conf中修改
  • FAST模式:执行频率不固定,但每次间隔不低于2ms,每次耗时不超过1ms

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

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

3. Redis过期删除策略用的哪种?

Redis是惰性删除和定期删除两种策略进行配合使用的。

相关推荐
fen_fen20 小时前
Oracle建表语句示例
数据库·oracle
砚边数影1 天前
数据可视化入门:Matplotlib 基础语法与折线图绘制
数据库·信息可视化·matplotlib·数据可视化·kingbase·数据库平替用金仓·金仓数据库
orange_tt1 天前
Djiango配置Celery
数据库·sqlite
云小逸1 天前
【nmap源码学习】 Nmap网络扫描工具深度解析:从基础参数到核心扫描逻辑
网络·数据库·学习
肉包_5111 天前
两个数据库互锁,用全局变量互锁会偶发软件卡死
开发语言·数据库·c++
霖霖总总1 天前
[小技巧64]深入解析 MySQL InnoDB 的 Checkpoint 机制:原理、类型与调优
数据库·mysql
ALex_zry1 天前
Redis Cluster 分布式缓存架构设计与实践
redis·分布式·缓存
此刻你1 天前
常用的 SQL 语句
数据库·sql·oracle
それども1 天前
分库分表的事务问题 - 怎么实现事务
java·数据库·mysql
·云扬·1 天前
MySQL Binlog 配置指南与核心作用解析
数据库·mysql·adb