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

一. Redis缓存过期机制

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

1. (主动)定期删除

定时随机的检查过期的key,如果过期则清理删除。每秒检查次数在redis.conf中的hz配置,如下图则设置了每秒检查10次。

Redis缓存过期机制与内存淘汰机制_第1张图片

2. (被动)惰性删除

当客户端请求一个已经过期的key的时候,那么redis会检查这个key是否过期,如果过期了,则删除,然后返回一个nil。这种策略对cpu比较友好,不会有太多的损耗,但是内存占用会比较高。

以上是针对设置了expire过期的数据 

二、内存淘汰管理机制 

当内存占用满了以后,redis提供了一套缓存淘汰机制:MEMORY MANAGEMENT

可以通过修改 redis.conf 中的 maxmemory 大小来实现。

maxmemory:当内存已使用率到达,则开始清理缓存

Redis缓存过期机制与内存淘汰机制_第2张图片

另外还有一些淘汰策略如下: 

Redis缓存过期机制与内存淘汰机制_第3张图片

* noeviction:旧缓存永不过期,新缓存设置不了,返回错误
* allkeys-lru:清除最少用的旧缓存,然后保存新的缓存(推荐使用)
* allkeys-random:在所有的缓存中随机删除(不推荐)
* volatile-lru:在那些设置了expire过期时间的缓存中,清除最少用的旧缓存,然后保存新的缓存
* volatile-random:在那些设置了expire过期时间的缓存中,随机删除缓存
* volatile-ttl:在那些设置了expire过期时间的缓存中,删除即将过期的

 

你可能感兴趣的:(Redis,缓存,redis,数据库)