回答
Redis 缓存满了后,Redis 会根据设置的缓存淘汰策略来处理新的写入操作。Redis提供了 8 种不同的缓存淘汰策略:
noeviction
:默认淘汰策略。不删除任何数据,当内存使用达到阈值时,所有尝试写入的操作都会报错。allkeys-random
:从所有 key 中随机选择并淘汰。allkeys-lru
:对所有 key 使用 LRU 算法进行删除。淘汰最近最少使用的键。allkeys-lfu
:对所有 key 使用 LFU 算法进行删除。淘汰访问频率最低的键。volatile-random
:对已设置过期时间的 key 随机删除。volatile-lru
:对已设置过期时间的 key 使用 LRU 算法进行删除。volatile-lfu
:对已设置过期时间的 key 使用 LFU 算法进行删除。volatile-ttl
:从已设置过期时间的键中选择将要最先过期的键进行淘汰。
更多阅读
扩展
调整 Redis 最大内存
在配置文件 redis.conf
中,可以调整参数 maxmemory
的值来配置 Redis 的最大内存,如调整到 2GB:
maxmemory 2gb
修改配置文件后,需要重启 Redis 服务才能使配置生效。
我们也可以使用命令在不重启 Redis 服务的情况下动态地设置最大内存:
CONFIG SET maxmemory 2gb
调整内存淘汰策略
获取当前的内存淘汰策略
config get maxmemory-policy
在配置文件 redis.conf
中,可以通过参数 maxmemory-policy
来配置,比如:
maxmemory-policy allkeys-lru
也需要重启 Redis 服务。
同时,Redis 也支持不重启 Redis 服务的情况下调整内存淘汰策略:
CONFIG SET maxmemory-policy allkeys-lru
防止 Redis 内存满
- 加内存:最简单、粗暴、有效的方式。
- 配置过期时间
- 优化数据存储
- 谨防大 key
- 使用监控工具(如Redis自带的监控命令、Prometheus等)来监控内存使用情况