Redis内存淘汰策略
Redis占用内存大小
- 通过配置文件配置
在配置文件redis.conf中添加如下配置设置内存大小
maxmemory 100mb
- 通过命令修改
//设置Redis最大占用内存大小为100M
127.0.0.1:6379>config set maxmemory 100mb
//获取设置的Redis能使用的最大内存大小
127.0.0.1:6379>config get maxmemory
如果不设置最大内存大小或者设置最大内存大小为0,在64位擦做系统下不限制内存大小,在32位操作系统下最多3GB内存(建议设置为物理机最大内存的3/4).
Redis内存淘汰策略
当内存用完的时候,还继续往Redis里面添加数据就没内存可用了,Redis定义了几种策略来处理这种情况:
- noeviction(默认策略):对于写请求不再提供服务,直接返回错误(DEL请求和部分特殊请求除外)
- allkeys-lru:从所有key中使用LRU算法进行淘汰
- volatile-lru:从设置了过期时间的key中使用LRU算法进行淘汰
- allkeys-random:从所有key中随机淘汰数据
- volatile-random:从设置了过期时间的key中随机淘汰
- volatile-ttl:在设置了过期时间的key中,根据key的过期时间进行淘汰,越早过期的越优先被淘汰
当使用volatile-lru、volatile-random、volatile-ttl这三种策略时,如果没有key可以被淘汰,则和noeviction一样返回错误
获取及设置内存淘汰策略
- 获取当前内存淘汰策略
127.0.0.1:6379> config get maxmemory-policy
- 通过配置文件设置淘汰策略(修改redis.conf文件
maxmemory-policy allkeys-lru
- 通过命令修改淘汰策略
127.0.0.1:6379> config set maxmemory-policy allkeys-lru