欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Redis运维和开发学习笔记(7) 内存管理和过期策略

程序员文章站 2022-06-11 17:07:57
...

Redis运维和开发学习笔记(7) 内存管理和过期策略

内存回收策略

惰性删除

惰性删除用于当客户端读取带有超时属性的键时,如果已经超过键设置的过期时间,会执行删除操作并返回空。不需要维护TTL链处理过期键的删除。如果有一个键从来没有被访问,那就有问题了。就需要定时任务删除

定时任务删除

默认每10秒执行一次,通过配置hz控制。定时任务中采用自适应算法。根据键的过期比例,使用快慢两种速率回收

maxmemory

内存达到maxmemory限制时触发内存溢出控制策略maxmemory-policy:六种策略

noeviction 默认不删除,拒绝所有写操作
volatile-lru 根据LRU算法删除设置了超时属性
allkeys-lru 根据lru算法删除键,不管数据有没有设置超时属性
volatile-random 随机删除过期键,知道腾出足够空间
volatile-ttl 根据键值对象的ttl属性,删除最近将要过期的数据,如果没有回退到noeviction
allkeys-random 随机删除所有键,直到有足够空闲空间

过期策略allkeys-lru主从搭建测试

搭建完毕主从

开辟2M空间,往里面写数据。1024条

  1. 使用脚本写入数据
for ((i=1;i<1024;i++))
do
    echo -en "helloworld1" | redis-cli -c -p 7010 -x set name$i
done
  1. 把数据输出
    共写入了108条数据这个时候我们再set数据查看变化

测试结果

volatile-lru测试结果

Redis运维和开发学习笔记(7) 内存管理和过期策略

volatile-ttl测试结果

Redis运维和开发学习笔记(7) 内存管理和过期策略

allkeys-lru

Redis运维和开发学习笔记(7) 内存管理和过期策略