Redis内存淘汰机制
内存淘汰机制就能保证在redis内存占用过高的时候,去进行内存淘汰,也就是删除一部分key,保证redis的内存占用率不会过高,那么它会淘汰哪些key呢?Redis目前共提供了8种内存淘汰策略,含Redis 4.0版本之后又新增的两种LFU模式:volatile-lfu和allkeys-lfu。 内存淘汰机制由redis.conf配置文件中的maxmemory-policy属性设置,没有配置时默认为no-eviction模式。
no-eviction | 当内存不足以容纳新写入数据时,新写入操作会报错,无法写入新数据,一般不采用。 |
---|---|
allkeys-lru | 当内存不足以容纳新写入数据时,移除最近最少使用的key,这个是最常用的 |
allkeys-random | 当内存不足以容纳新写入的数据时,随机移除key |
allkeys-lfu | 当内存不足以容纳新写入数据时,移除最不经常(最少)使用的key |
volatile-lru | 当内存不足以容纳新写入数据时,在设置了过期时间的key中,移除最近最少使用的key。 |
volatile-random | 内存不足以容纳新写入数据时,在设置了过期时间的key中,随机移除某个key 。 |
volatile-lfu | 当内存不足以容纳新写入数据时,在设置了过期时间的key中,移除最不经常(最少)使用的key |
volatile-ttl | 当内存不足以容纳新写入数据时,在设置了过期时间的key中,优先移除过期时间最早(剩余存活时间最短)的key。 |
淘汰策略的执行过程
客户端执行一条命令,导致Redis需要增加数据(比如set key value);
Redis会检查内存使用情况,如果内存使用超过 maxmemory,就会按照配置的置换策略maxmemory-policy删除一些key;
再执行新的数据的set操作;