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

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测试结果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-If4Ld9SW-1572053750520)(media/15662043330552/15674243431626.jpg)]

volatile-ttl测试结果

在这里插入图片描述

allkeys-lru

在这里插入图片描述

发布了257 篇原创文章 · 获赞 223 · 访问量 32万+

猜你喜欢

转载自blog.csdn.net/csdn_kou/article/details/102753120