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

相关推荐
∝请叫*我简单先生36 分钟前
Java 如何传参xml调用接口获取数据
xml·java·后端·传参xml调用接口
Json____44 分钟前
2. 使用springboot做一个音乐播放器软件项目【框架搭建与配置文件】
java·spring boot·后端·音乐播放器·音乐播放器项目·java项目练习·springboot练习
Pandaconda1 小时前
【新人系列】Python 入门(二十五):Socket 网络编程
开发语言·网络·笔记·后端·python·面试·网络编程
小禾家的1 小时前
asp.net core webapi 并发请求时 怎么保证实时获取的用户信息是此次请求的?
后端·asp.net
Libby博仙1 小时前
asp.net core mvc中的模板页(父页面,布局页)和部分视图(Partial View)
后端·asp.net·mvc
曦月合一2 小时前
java中日期如何比大小
java·开发语言·后端
CyberScriptor2 小时前
Swift语言的正则表达式
开发语言·后端·golang
Code侠客行3 小时前
Perl语言的循环实现
开发语言·后端·golang
Quantum&Coder3 小时前
MATLAB语言的数据库交互
开发语言·后端·golang
网络空间站3 小时前
MATLAB语言的软件工程
开发语言·后端·golang