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过去被访问次数最少的一条数据
相关推荐
广州智造4 小时前
OptiStruct实例:3D实体转子分析
数据库·人工智能·算法·机器学习·数学建模·3d·性能优化
技术宝哥7 小时前
Redis(2):Redis + Lua为什么可以实现原子性
数据库·redis·lua
学地理的小胖砸8 小时前
【Python 操作 MySQL 数据库】
数据库·python·mysql
呦呦鹿鸣Rzh8 小时前
缓存的相关内容
缓存
dddaidai1239 小时前
Redis解析
数据库·redis·缓存
数据库幼崽9 小时前
MySQL 8.0 OCP 1Z0-908 121-130题
数据库·mysql·ocp
Amctwd9 小时前
【SQL】如何在 SQL 中统计结构化字符串的特征频率
数据库·sql
工一木子9 小时前
【Java项目脚手架系列】第七篇:Spring Boot + Redis项目脚手架
java·spring boot·redis
betazhou9 小时前
基于Linux环境实现Oracle goldengate远程抽取MySQL同步数据到MySQL
linux·数据库·mysql·oracle·ogg
lyrhhhhhhhh10 小时前
Spring 框架 JDBC 模板技术详解
java·数据库·spring