Redis 过期删除策略 And 内存淘汰策略 !!!

一、Redis过期删除策略(什么时候删除)

1、惰性删除:放任键过期不管,但是每次从键空间中获取键时,都检查取得的键是否过期,如果过期的话就删除该键,如果没有过期就返回该键。

2、定期删除:每隔一段时间程序就对数据库进行一次检查,删除里面的过期键。至于要删除多少过期键,一级哟啊检查多少个数据库,则有算法决定。

二、内存淘汰策略(删除什么)

Redis 内存数据集大小上升到一定大小的时候,就会施行数据淘汰策略。

Redis 提供 8 种数据淘汰策略:

LRU全称Least recently used,意思为淘汰掉最久未使用(即最老)的一条数据;

LFU全称Least-frequently used,意思为淘汰掉过去被访问次数最少的一条数据

淘汰策略名称 策略含义 人话
noeviction 默认策略,不淘汰数据;大部分写命令都将返回错误 不删除任意数据 (但redis还会根据引用计数器进行释放),这时如果内存不够时,会直接返回错误
volatile-lru 设置了过期时间的数据 中根据LRU 算法挑选数据淘汰(只针对设置过期的keys 设置了过期时间的数据 集中,选择最近最久未使用的数据释放 ,最老的删掉
allkeys-lru这个是最常用的 所有数据 中根据 LRU 算法挑选数据淘汰(所有keys 所有相数据 中(包括设置过期时间以及未设置过期时间的数据集中),选择最近最久未使用 的数据释放 最老的删掉
allkeys-random 所有数据随机挑选数据淘汰 随机选择一个数据进行释放;
volatile-random 设置了过期时间 的数据中随机挑选数据淘汰 设置了过期时间的数据 集中,随机
volatile-ttl 设置了过期时间 的数据中,挑选越早过期的数据进行删除 设置了过期时间的数据 集中,选择马上 就要过期的数据进行释放操作
allkeys-lfu 所有数据 中根据 LFU 算法挑选数据淘汰(4.0及以上版本可用) 淘汰掉所有数据 过去被访问次数最少的一条数据
volatile-lfu 从设置了过期时间的数据 中根据 LFU 算法挑选数据淘汰(4.0及以上版本可用) 淘汰掉设置了过期时间的 key过去被访问次数最少的一条数据
相关推荐
Tapdata1 小时前
《实时分析市场报告 2025》上线 | 从批处理到实时洞察,2025 年全球实时分析市场全景解读
数据库
海梨花1 小时前
【从零开始学习Redis】项目实战-黑马点评D2
java·数据库·redis·后端·缓存
代码的余温3 小时前
SQL性能优化全攻略
数据库·mysql·性能优化
手把手入门5 小时前
★CentOS:MySQL数据备份
数据库·mysql·adb
SelectDB6 小时前
5000+ 中大型企业首选的 Doris,在稳定性的提升上究竟花了多大的功夫?
大数据·数据库·apache
路多辛6 小时前
Golang database/sql 包深度解析(二):连接池实现原理
数据库·sql·golang
SimonKing6 小时前
Mybatis批量插入,形式不同性能也不同
数据库·后端·程序员
杰克尼7 小时前
MYSQL-175. 组合两个表
数据库·mysql
DemonAvenger7 小时前
MySQL索引原理深度解析与优化策略实战
数据库·mysql·性能优化
189228048618 小时前
NY270NY273美光固态闪存NY277NY287
服务器·网络·数据库·科技·性能优化