Redis缓存过期处理与内存淘汰机制

引子

Redis的高并发都是基于内存的

已过期的key如何处理?

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

  1. (主动)定时删除
    定时随机的检查过期key,如果过期则清理删除。(每秒检查数在redis.conf中hz配置)
  2. (被动)惰性删除
    当客户端请求一个key时,那么redis会检查这个key是否过期,如果过期,则删除,返回nil。对CPU比较友好,但内存会占用比较高。

内容被Redis缓存占用慢了如何处理?

Redis提供了一套缓存淘汰机制:MEMORY MANAGEMENT

# 当内存达到时候,开始清理内存
maxmemory 
#淘汰策略
maxmemory-policy   
  • noeviction:旧缓存永不过期,新缓存设置不了,返回错误
  • allkeys-lru: 清除最少用(闲置时间)的旧缓存,然后保存新的缓存(推荐使用)
  • allkeys-lfu: 清除最少用(使用频率最少)的旧缓存,然后保存新的缓存
  • allkeys-random:在所有的缓存中随机删除(不推荐)
  • volatile-lru:在那些设置了expire过期时间的缓存中,清除最少用的旧缓存(闲置时间),然后保存新的缓存
  • volatile-lfu:在那些设置了expire过期时间的缓存中,清除最少用的旧缓存(使用频率最少),然后保存新的缓存
  • volatile- random:在那些设置了expire过期时间的缓存中,随机删除缓存
  • volatile-ttl:在那些设置了expire过期时间的缓存中,删除即将过期的

你可能感兴趣的:(redis,Redis缓存过期)