## 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操作;**
- 转载请注明来源:Redis内存淘汰机制
- 本文永久链接地址:http://icehill.cn/post/single/info/264.html