Redis缓存过期淘汰策略详讲

查看redis最大占用内存

1)命令查看

config get memory

2)进入redis配置文件,查看maxmemory

vim /myredis/redis.conf

3)redis默认内存多少可用

如果不设置最大内存大小或者设置最大内存大小为0,在64位操作系统不限制内存大小,在32位操作系统下最多3g

4)一般生产上如何配置,maxmemory单位是byte

类似hashmap,负载因子为0.75 ,所以一般设置为内存为物理内存的四分之三

5)如何修改

修改文件vim /myredis/redis.conf

利用命令:config set maxmemory 1024000

6)什么命令查看redis内存情况

info memory

可以查看各种信息,包括内存、持久化

内存不足会怎样,

1)设置内存值为1,报OOM command

2)要防止内存被占满,所以就要内存过期淘汰

内存淘汰策略

1.定时删除(对CPU不好,用处理器的性能换取存储空间):

redis不可能时时刻刻遍历所有被设置生存时间的key,来检查数据是否达到过期时间,然后对他删除。

立即删除可以保证数据最新,不占用redis内存,但是对CPU不友好,假设CPU正忙,这时候又要删除,产生大量的性能消耗,影响数据的读取操作。

拿处理器性能换取储存空间

2.惰性删除(对内存不友好,再一次访问删除):

数据达到过期不做删除。等待下次访问该数据时,如果未过期,返回数据,发现已过期,删除,返回不存在。大量不用的垃圾占用内存。

上面两种方案极端情况:

定期删除:每隔一段时间执行一次删除过期操作,主要考虑确定删除的key、定期扫描的时长,什么时候扫描,内存淘汰策略就可以解决这个问题。

1)redis天生自带淘汰策略:

redis6默认有8种

两个维度:过期key volatile,全部key allkey

四个方面:

LRU,Least Recently Used ,最近最少使用的

LFU,Less Frequently Used ,一直以来最少被使用的元素会被被清理掉

random

ttl + noeviction

默认等待打满,noeviction,不在驱除,报OOM

2)配置淘汰策略

修改redis.conf配置:

maxmemory- policy allkeys- lru

命令配置:

config set maxmemory- policy allkeys- lru

相关推荐
It's now4 分钟前
Spring Framework 7.0 原生弹性功能系统讲解
java·后端·spring
无限大611 分钟前
Agent 入门科普:从"人工智障"到"数字打工人"的进化史
后端
一 乐33 分钟前
人事管理系统|基于Springboot+vue的企业人力资源管理系统设计与实现(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot·后端
SelectDB39 分钟前
浙江头部城商行:每日 700 万查询、秒级响应,Apache Doris 查算分离架构破局资源冲突
数据库·后端·apache
追逐时光者1 小时前
分享 4 款基于 C# 编写、实用、开源的 Visual Studio 扩展插件
后端·.net·visual studio
vx_bisheyuange2 小时前
基于SpringBoot的社区养老服务系统
java·spring boot·后端·毕业设计
sheji34162 小时前
【开题答辩全过程】以 基于Springboot的超市仓库管理系统设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
武藤一雄3 小时前
C# 语法糖详解
后端·microsoft·c#·.net
qq_12498707533 小时前
基于SpringBoot学生学习历史的选课推荐系统的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·学习·毕业设计·毕设
武藤一雄3 小时前
C#:进程/线程/多线程/AppDomain详解
后端·微软·c#·asp.net·.net·wpf·.netcore