• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    浅谈Redis缓存有哪些淘汰策略

    Redis过期策略

    我们首先来了解一下Redis的内存淘汰机制。

    定时删除

    概述
        redis默认是每隔 100ms 就随机抽取一些设置了过期时间的key,检查其是否过期,如果过期就删除。注意这里是随机抽取的。为什么要随机呢?你想一想假如 redis 存了几十万个 key ,每隔100ms就遍历所有的设置过期时间的 key 的话,就会给 CPU 带来很大的负载!

    优点

    缺点

    总结

    用处理器性能换取存储空间 (拿时间换空间)

    惰性删除

    key过期的时候不删除,每次从数据库获取key的时候去检查是否过期,若过期,则删除,返回null。

    优点

    缺点

    总结

    用存储空间换取处理器性能(拿空间换时间)

    定期删除

    如果当前库中没有一个key设置了过期时间,直接执行下一个库的遍历,随机获取一个设置了过期时间的key,检查该key是否过期,如果过期,删除key,判断定期删除操作是否已经达到指定时长,若已经达到,直接退出定期删除。(默认每个库检测20个key)

    优点

    缺点

    Redis的内存淘汰机制

    简述
    Redis有过期策略,假如你的Redis只能存1G的数据,你一个请求写入2G,而你也没有及时请求key,那么惰性删除就不生效了,Redis占用内存就会越来越高。

    Redis可以设置内存大小:

    # maxmemory bytes>
    # 设置Redis最大占用内存大小为100
    maxmemory 100mb
    

    超过了这个内存大小,就会触发内存淘汰机制,Redis有一个默认配置,这个是Redis的默认 内存淘汰机制:

    # maxmemory-policy noeviction
    

    maxmemory-policy一共有8个值,当内存不足时:

    LRU和LFU的区别

    LRU

    LRU是最近最少使用页面置换算法(Least Recently Used),也就是首先淘汰最长时间未被使用的页面!
    比如有数据 1,1,1,2,2,3 此时缓存中已有(1,2) 当3加入的时候,得把前面的1淘汰,变成(3,2)

    LFU

    LFU是最近最不常用页面置换算法(Least Frequently Used),也就是淘汰一定时期内被访问次数最少的页!

    比如有数据 1,1,1,2,2,3 缓存中有(1(3次),2(2次)) 当3加入的时候,得把后面的2淘汰,变成(1(3次),3(1次))

    Redis重启如何恢复数据呢?

    Redis启动前会先检查AOF文件,不存在才会去加载RDB文件,因为AOF的数据完整性高,最多也就损失1秒的数据。

    总结

    到此这篇关于浅谈Redis缓存有哪些淘汰策略的文章就介绍到这了,更多相关Redis缓存淘汰策略内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • Redis中LRU淘汰策略的深入分析
    • 关于redis Key淘汰策略的实现方法
    • 浅谈redis的maxmemory设置以及淘汰策略
    上一篇:Redis底层数据结构详解
    下一篇:Redis通过scan查找不过期的 key(方法详解)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    浅谈Redis缓存有哪些淘汰策略 浅谈,Redis,缓,存有,哪些,