-
背景
- redis在占用的内存超过指定的maxmemory之后,通过maxmemory_policy确定redis是否释放内存以及如何释放内存
- 提供多种策略
-
策略
-
volatile-lru(least recently used)
- 最近最少使用算法,从设置了过期时间的键中选择空转时间最长的键值对清除掉
-
volatile-lfu(least frequently used)
- 最近最不经常使用算法,从设置了过期时间的键中选择某段时间之内使用频次最小的键值对清除掉
-
volatile-ttl
- 从设置了过期时间的键中选择过期时间最早的键值对清除(删除即将过期的)
-
volatile-random
- 从设置了过期时间的键中,随机选择键进行清除
-
allkeys-lru
- 最近最少使用算法,从所有的键中选择空转时间最长的键值对清除
-
allkeys-lfu
- 最近最不经常使用算法,从所有的键中选择某段时间之内使用频次最少的键值对清除
-
allkeys-random
- 所有的键中,随机选择键进行删除
-
noeviction
- 不做任何的清理工作,在redis的内存超过限制之后,所有的写入操作都会返回错误,但是读操作都能正常的进行
-
config配置的时候下划线_的key需要用中横线-
127.0.0.1:6379> config set maxmemory_policy volatile-lru (error) ERR Unsupported CONFIG parameter: maxmemory_policy 127.0.0.1:6379> config set maxmemory-policy volatile-lru OK
-
相关文章
- 12-26内存分配策略:minor gc前后的几种特殊情况
- 12-26垃圾收集器与内存分配策略---内存的分配与回收
- 12-26c-内存/速度问题的一般策略
- 12-26JVM之垃圾回收器与内存分配策略 的关键点
- 12-26【redis前传】自己手写一个LRU策略 | redis淘汰策略
- 12-26Redis批量删除key的命令
- 12-26Redis如何处理过期了的key
- 12-26Redis内存淘汰
- 12-26缓存的有效期和淘汰策略
- 12-26关于redis key命名规范的设计