Redis内存不足解决方案


目录

问题

解决方案

1、通过设置多级缓存,降低redis内存使用和访问次数

2、利用redis-rdb-tools工具或MEMORY USAGE对内存进行分析

3、通过Redis的缓存清除及缓存淘汰策略对内存进行清理


问题

当大量数据存放在Redis中,受限于机器硬件内存大小,会存在内存不足的情况,那么解决内存不足的方案有哪些呢?

解决方案

1、通过设置多级缓存,降低redis内存使用和访问次数

2、利用redis-rdb-tools工具或MEMORY USAGE对内存进行分析

3、通过Redis的缓存清除及缓存淘汰策略对内存进行清理

Redis清除策略:

  • 定时删除:周期性探测,将已过期的key进行剔除
  • 惰性删除:在访问前检查是否失效,失效便进行删除
  • 主动删除:内存超过maxmemory限定时,触发缓存淘汰策略

Redis缓存淘汰策略:

  • volatile-lru:从已设置过期时间的数据中挑选最近最少使用的数据淘汰;
  • allkeys-lru:从数据集中挑选最近最少使用的数据淘汰;
  • volatile-lfu:从已设置过期时间的数据集挑选使用频率最低的数据淘汰。
  • allkeys-lfu:从数据集中挑选使用频率最低的数据淘汰。
  • volatile-random:从已设置过期时间的数据中任意选择数据淘汰;
  • allkeys-random:从数据集中任意选择数据淘汰;
  • volatile-ttl:从已设置过期时间的数据中挑选将要过期的数据淘汰;
  • no-enviction(驱逐):禁止驱逐数据,引发OOM