引子
Redis的高并发都是基于内存的
已过期的key如何处理?
设置了expire的key缓存过期了,但是服务器的内存还是会被占用,这是因为Redis的两种删除策略
- (主动)定时删除
定时随机的检查过期key,如果过期则清理删除。(每秒检查数在redis.conf中hz配置) - (被动)惰性删除
当客户端请求一个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过期时间的缓存中,删除即将过期的