【redis】redis的过期策略以及内存淘汰机制

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

在这里插入图片描述

前言

今天我们讨论下redis的过期策略以及内存淘汰机制如果你想要考察一个人对redis的了解那吗这个问题是必选的从他对这个问题的回答中就可以了解到他的redis深浅。

过期策略

先来介绍下Redis key 过期删除的策略有三种方式

  • 被动删除当读/写一个已经过期的key时会触发惰性删除策略直接删除掉这个过期key。
  • 主动删除由于惰性删除策略无法保证冷数据被及时删掉所以Redis会定期主动淘汰一批已过期的key。

但了解这些还不够你还应该继续追问下去


比如你redis只能存5G数据可是你 写了10G那会删5G的数据。怎么删的这个问题思考过么? 还有你的数据已经设置了过期时间但是时间到 了内存占用率还是比较高有思考过原因么?
redis采用的是定期删除+惰性删除策略


为什么不用定时删 除策略?
定时删除,用一个定时器来负责监视key,过期则自动删除。虽然内存及时释放但是十分消耗CPU资源。在 大并发请求下CPU要将时间应用在处理请求而不是删除key,因此没有采用这一策略


定期删除+惰性删除是如何 工作的呢?
定期删除redis默认每个100ms检查是否有过期的key有过期key则删除。需要说明的是redis不是 每个100ms将所有的key检查一次而是随机抽取进行检查(如果每隔100ms,全部key进行检查redis岂不是卡 死)。因此如果只采用定期删除策略会导致很多key到时间没有删除。 于是惰性删除派上用场。也就是说在你 获取某个key的时候redis会检查一下这个key如果设置了过期时间那么是否过期了?如果过期了此时就会删 除。


采用定期删除+惰性删除就没其他问题了么?
不是的如果定期删除没删除key。然后你也没即时去请求key 也就是说惰性删除也没生效。这样redis的内存会越来越高。那么就应该采用内存淘汰机制。 在redis.conf中有一 行配置

   # maxmemory-policy volatile-lru

内存淘汰机制

上面的这行代码配置就是配内存淘汰策略的(什么你没配过?好好反省一下自己) 。

  1. noeviction当内存不足以容纳新写入数据时新写入操作会报错。应该没人用吧。
  2. allkeys-lru当内存不足以容纳新写入数据时在键空间中移除最近最少使用的key。推荐使用目前项目在用这种。
  3. allkeys-random当内存不足以容纳新写入数据时在键空间中随机移除某个key。应该也没人用吧你不删最少使用Key。去随机删。
  4. volatile-lru当内存不足以容纳新写入数据时在设置了过期时间的键空间中移除最近最少使用的key。这种情况一般是把redis既当缓存又做持久化存储的时候才用。不推荐
  5. volatile-random当内存不足以容纳新写入数据时在设置了过期时间的键 空间中随机移除某个key。依然不推荐
  6. volatile-ttl当内存不足以容纳新写入数据时在设置了过期时间的键 空间中有更早过期时间的key优先移除。不推荐

那么你对redis的过期策略以及内存淘汰机制了解多少呢

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: redis