zoukankan      html  css  js  c++  java
  • Redis 缓存过期处理与内存淘汰机制

    引子

    计算机内存有限,越大越贵,Redis的高并发高性能都是基于内存的,用硬盘的话GG。

    已过期的key如何处理?

    设置了expire的key缓存过期了,但是服务器的内存还是会被占用,这是因为redis所基于的两种删除策略
    redis有两种策略:

    1. (主动)定时删除
      定时随机的检查过期的key,如果过期则清理删除。(每秒检查次数在redis.conf中的hz配置)
    2. (被动)惰性删除
      当客户端请求一个已经过期的key的时候,那么redis会检查这个key是否过期,如果过期了,则删除,然后返回一个nil。这种策略
      友好,不会有太多的损耗,但是内存占用会比较高。
      所以,虽然key过期了,但是只要没有被redis清理,那么其实内存还是会被占用着的。

    那么如果内存被Redis缓存占用慢了咋办?

    内存占满了,可以使用硬盘,来保存,但是没意义,因为硬盘没有内存快,会影响redis性能。
    所以,当内存占用满了以后,redis提供了一套缓存淘汰机制:MEMORY MANAGEMENT
    maxmemory :当内存已使用率到达,则开始清理缓存

    * noeviction:旧缓存永不过期,新缓存设置不了,返回错误
    * allkeys-lru:清除最少用的旧缓存,然后保存新的缓存(推荐使用)
    * allkeys-random:在所有的缓存中随机删除(不推荐)
    * volatile-lru:在那些设置了expire过期时间的缓存中,清除最少用的旧缓存,然后保存新的缓存
    * volatile-random:在那些设置了expire过期时间的缓存中,随机删除缓存
    * volatile-ttl:在那些设置了expire过期时间的缓存中,删除即将过期的
    
  • 相关阅读:
    man date
    Python---Tkinter---贪吃蛇
    Python---TKinter项目实战---屏保
    虚拟化之kvm --(vnc控制台)
    cisco和华为的设备如何设置命令不分页显示
    liunx之Centos6.8杀毒软件的安装
    Liunx系统命令sed的使用
    自动运维之网络设备割接配置按预定步骤操作
    mutt+msmtp实现在shell环境中发送电子邮件
    windowns下excel2013快速生成月报表
  • 原文地址:https://www.cnblogs.com/hardy-wang/p/13845584.html
Copyright © 2011-2022 走看看