redis淘汰策略复习
前面复习了 redis 的过期策略,这里再复习下淘汰策略,淘汰跟过期的区别有时候会被混淆了,过期主要针对那些设置了过期时间的 key,应该说是一种逻辑策略,是主动的还是被动的加定时的,两种有各自的取舍,而淘汰也可以看成是一种保持系统稳定的策略,因为如果内存满了,不采取任何策略处理,那大概率会导致系统故障,之前其实主要从源码角度分析过redis 的 LRU 和 LFU,但这个是偏底层的实现,抠得比较细,那么具体的系统层面的配置是有哪些策略,来看下 redis labs 的介绍
Policy | Description |
---|---|
noeviction 不逐出 | Returns an error if the memory limit has been reached when trying to insert more data,插入更多数据时,如果内存达到上限了,返回错误 |
allkeys-lru 所有的 key 使用 lru 逐出 | Evicts the least recently used keys out of all keys 在所有 key 中逐出最近最少使用的 |
allkeys-lfu 所有的 key 使用 lfu 逐出 | Evicts the least frequently used keys out of all keys 在所有 key 中逐出最近最不频繁使用的 |
allkeys-random 所有的 key 中随机逐出 | Randomly evicts keys out of all keys 在所有 key 中随机逐出 |
volatile-lru | Evicts the least recently used keys out of all keys with an “expire” field set 在设置了过期时间的 key 空间 expire 中使用 lru 策略逐出 |
volatile-lfu | Evicts the least frequently used keys out of all keys with an “expire” field set 在设置了过期时间的 key 空间 expire 中使用 lfu 策略逐出 |
volatile-random | Randomly evicts keys with an “expire” field set 在设置了过期时间的 key 空间 expire 中随机逐出 |
volatile-ttl | Evicts the shortest time-to-live keys out of all keys with an “expire” field set.在设置了过期时间的 key 空间 expire 中逐出更早过期的 |
而在这其中默认使用的策略是 volatile-lru,对 lru 跟 lfu 想有更多的了解可以看下我之前的文章redis系列介绍八-淘汰策略