前言
查看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