目录
- 当Redis的内存满了我们怎么办?
- 返回Redis目录
当Redis的内存满了我们怎么办?
- 增加内存
- 使用内存淘汰策略,也就是在配置文件中设置
maxmemory
参数,该参数控制最大可用内存(字节),当内存上线超过该参数时,maxmemory-policy
。maxmemory-policy
有以下几种淘汰规则:
规则 | 描述 |
noeviction | 默认参数,不删除键,只返回错误 |
volatile-lru | 使用LRU算法删除一个设置了生存时间的键 |
allkeys-lru | 使用LRU算法删除一个键 |
volatile-ttl | 删除生存时间最近的一个键 |
volatile-random | 随机删除一个设置了生存时间的键 |
allkeys-random | 随机删除一个键 |
注意:LRU(least RecentlyUsed)算法和 |
- 使用Redis集群,可以有三种方式:
- 客户端分片:通过业务代码自己实现路由,优势是可以控制分片算法,性能相对较好;劣势是维护成本高、扩容/缩容等运维操作需要自己研发
- 代理分片:代理程序接收到来自业务程序的数据请求,根据路由规则,将这些请求分发给正确的Redis实例并返回给业务程序。使用类似Twemproxy、Codis等中间件实现。优势是运维方便、程序不用关心如何链接Redis实例;劣势是会带来性能消耗(大概20%)、无法平滑扩容/缩容,需要执行脚本迁移数据,不方便(Codis在Twemproxy基础上优化并实现了预分片来达到Auto Rebalance)。
- Redis Cluster:优势:官方集群解决方案、无中心节点,和客户端直连,性能较好;劣势:方案太重、无法平滑扩容/缩容,需要执行相应的脚本,不方便、太新,没有相应成熟的解决案例。