专栏首页CoxhuangRedis(七)---淘汰删除策略

Redis(七)---淘汰删除策略

Redis(一)-----主从复制 : https://blog.csdn.net/Coxhuang/article/details/104645557 Redis(二)-----数据分区 : https://blog.csdn.net/Coxhuang/article/details/104645989 Redis(三)-----集群方案 : https://blog.csdn.net/Coxhuang/article/details/104667132 Redis(四)-----持久化 : https://blog.csdn.net/Coxhuang/article/details/104682409 Redis(五)-----应用场景 : https://blog.csdn.net/Coxhuang/article/details/104688015 Redis(六)-----缓存穿透/缓存雪崩/缓存击穿 : https://blog.csdn.net/Coxhuang/article/details/104688168 Redis(七)—淘汰删除策略 : https://blog.csdn.net/Coxhuang/article/details/104788308

Redis 淘汰删除策略

#1 六种淘汰Key策略

Redis中通过maxmemory参数来设定内存的使用上限,当Redis使用内存达到设定的最大值的时候,会根据配置文件中的策略选取要删除的key来删除,从而给新的键值留出空间

配置文件中maxmemory-policy可以设置删除redis键

规则名称

规则说明

noeviction (默认)

不删除键,只返回错误

volatile-lru

在设置了过期时间的键空间中,移除最近最少使用的key

allkeys-lru

在所有的key中,移除最近最少使用的key

volatile-random

在设置了过期时间的键空间中,随机移除一个key

allkeys-random

在所有的key中,随机删除一个键

volatile-ttl

在设置了过期时间的键空间中,移除将要过期的key

LRU算法,least RecentlyUsed,最近最少使用算法。也就是说默认删除最近最少使用的键。

但是一定要注意一点!redis中并不会准确的删除所有键中最近最少使用的键,而是随机抽取3个键,删除这三个键中最近最少使用的键。 那么3这个数字也是可以设置的,对应位置是配置文件中的maxmeory-samples.

#2 三种删除过期键策略

前面我们知道需要淘汰掉哪些过期Key,但是我们应该怎么去淘汰这些过期key呢?有3种删除的操作策略:

#2.1 定时删除

在设置键的过期时间的同时,创建一个定时器,让定时器在键的过期时间来临时,立即执行对键的删除操作;

定时删除操作对于内存来说是友好的,内存不需要操作,而是通过使用定时器,可以保证尽快的将过期键删除,但是对于CPU来说不是友好的,如果过期键比较多的话,起的定时器也会比较多,删除的这个操作会占用到CPU的资源;

#2.2 惰性删除

放任键过期不管,但是每次从键空间中获取键时,都检查取得的键的过期时间,如果过期的话,删除即可;

惰性操作对于CPU来说是友好的,过期键只有在程序读取时判断是否过期才删除掉,而且也只会删除这一个过期键,但是对于内存来说是不友好的,如果多个键都已经过期了,而这些键又恰好没有被访问,那么这部分的内存就都不会被释放出来;

#2.3 定期删除

每隔一段时间,程序就对数据库进行一次检查,删除掉过期键;

定期删除是上面两种方案的折中方案,每隔一段时间来删除过期键,并通过限制删除操作执行的时长和频率来减少删除操作对CPU时间的影响,除此之外,还有效的减少内存的浪费;但是该策略的难点在于间隔时长,这个需要根据自身业务情况来进行设置;

目前,Redis采用的是惰性删除+定期删除的方案;

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Django 遇到的坑

    Coxhuang
  • Web安全(二)---跨域资源共享

    CORS是一个W3C标准,全称是"跨域资源共享"(Cross-origin resource sharing)。

    Coxhuang
  • Django Celery4 定时任务配置和使用

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HmAFvGY0-1591876971277)(https://raw.githu...

    Coxhuang
  • Redis过期策略以及内存淘汰机制

    如果你的 Redis 只能存10G数据,你写了12G,那么 Redis 会怎么淘汰那2G数据呢?

    ITer.996
  • 线程应用 - 中断interrupt详解

    有些初学者对中断的概念可能会有些许小误会,比如线程调用Thread.interrupt()方法,就认为线程会被中断,停止执行,其实不是这样的,让我们来看...

    虞大大
  • 开发|微信小程序与tensorflow.js准备工作

    这篇文章主要讲解如何将tensorflow与微信小程序结合,使得tensorflow的模型能够在微信小程序上呈现出来。

    算法与编程之美
  • 依赖倒转原则 -- 强执若 or 弱执强?

    故事是别人的,不过放在这里也是很应景啦。 故事是这样的: 有个适龄小伙子,他还单着。有一天,他喜欢的那个姑娘突然给他打电话,说她的电脑坏了,一用就蓝屏警告。...

    看、未来
  • 中国狼玩群体战 中国网络最大整合并购潮来临!

    中国网络超级玩家吹起“大收购”风暴,最大手笔的是阿里巴巴,五十六亿美元收购视频网优酷土豆,创造了中国互联网第一并购案。 另一起案子则是旅游网站老大携程网成为老二...

    人称T客
  • 面向对象之继承

    继上篇博客 https://www.cnblogs.com/qianqian-it/p/9526634.html 简单介绍了有关call和apply的联系和区别...

    用户3159471
  • Android开发实现TextView超链接5种方式源码实例

    autoLink属性一共有六个值,分别是none(正常),web(将文本识别为一个网址),phone(将文本识别为一个电话号码),mail(将文本识别为一个邮件...

    砸漏

扫码关注云+社区

领取腾讯云代金券