redis6的key过期时间删除策略

  • 背景
    • redis的key配置了过期时间,这个是怎么被删除的?
    • redis数据明明过期了,怎么还占用着内存?
    • redis就只能用10G,你要是往里面写了20G的数据,会发生什么?淘汰哪些数据?
  • redis key过期策略
    • 定期删除+惰性删除
  • redis如何淘汰过期的key:set name zhangsan 3600
    • 定期删除:
      • 隔一段时间,就随机抽取一些设置了过期时间的key,检查其是否过期,如果过期就删除
      • 定期删除可能会导致很多过期key到了时间并没有被删除掉,那咋办呢,所以就是惰性删除
    • 惰性删除:
      • 概念:当一些客户端尝试访问它时,key会被发现并主动的过期
      • 放任键过期不管,但是每次从键空间中获取键时,都检查取得的键是否过期,如果过期的话,就删除该键
    • redis服务器实际使用的是惰性删除和定期删除两种策略,通过配合使用这两种删除策略,服务器可以很好的在合理使用CPU时间和避免浪费内存空间之间取得平衡
  • 问题
    • 如果定期删除漏掉了很多过期的key,然后你也没及时去查,也就没走惰性删除,此时会怎么样?
    • 如果大量过期key堆积在内存里,导致redis内存块耗尽了,就需要走内存淘汰机制
  • 设计缓存中间件:可以参考redis的key过期淘汰方式和内存不足淘汰方式
posted @ 2021-07-28 17:29  Gen2021  阅读(106)  评论(0编辑  收藏  举报