redis高级(存储能力问题)

存储能力问题

主从和哨兵可以解决高可用、高并发读的问题。但是存在两个问题:

  • 海量数据存储问题
  • 高并发写问题

使用分片集群可以解决上述问题:

  • 集群中有多个master,每个master保存不同数据
  • 每个master都可以有多个slave节点
  • master之间通过ping检测彼此健康状态
  • 客户端请求可以访问集群任意节点,最终都会被发到正确节点

散列插槽

redis会把每一个master节点映射到0~16383共16384个插槽(hash slot)上,查看集群信息时就能看到:

数据key不是与节点绑定,而是与插槽绑定。redis会根据key的有效部分计算插槽值,分两种情况:

  • key中包含{},且其中至少1个字符,{}中的部分是有效部分
  • key中不包含{},整个key都是有效部分

redis如何判断某个key应该在哪个实例:

  • 将16384个插槽分配到不同的实例
  • 根据key的有效部分计算哈希值,对16384取余
  • 余数作为插槽,寻找插槽所在实例

如何将同一类数据固定的保存在同一个redis实例:

  • 这一类数据使用相同的有效部分,例如key都以{typeid}为前缀

集群伸缩

查看帮助文档

故障转移

当集群中有一个master宕机会发生什么

  1. 首先是该实例失去连接
  2. 然后是疑似宕机
  3. 最后是确定下线,自动提成一个slave为新的master

手动故障转移:

利用cluster failover命令可以手动让集群中的某个master宕机,切换到执行cluster failover命令的这个slave节点,实现无感知的数据迁移,流程:

  1. slave节点告诉master节点拒绝任何客户端请求
  2. master返回当前的数据offset给slave
  3. 等待offset与master一致
  4. 开始故障转移
  5. 标记自己为master,广播故障转移的结果

手动的failover支持三种不同模式:

  • 缺省:默认流程,如上
  • force:省略对offset的一致性校验
  • takeover:直接执行第五步,忽略数据一致性、忽略master状态和其他master的意见

RedisTemplate访问分片集群

方式与哨兵基本一致:

  1. 引入redis的starter依赖
  2. 配置分片集群地址(所有)
  3. 配置读写分离
相关推荐
数据库小学妹15 分钟前
AI时代数据库怎么选?多模融合、数据统一存储与选型实战指南
数据库·人工智能·经验分享·ai
Albert Edison24 分钟前
【Redis】Centos7.9 安装 Redis 5 教程
数据库·redis·缓存
云计算磊哥@41 分钟前
运维开发宝典026-MySQL02数据库表操作
运维·数据库·运维开发
Steadfast_GG1 小时前
Redis中的通用命令
redis·缓存
小二·1 小时前
Redis 内存溢出(OOM)排查与恢复实战
数据库·redis·bootstrap
pqk6V6Vep1 小时前
Redis 分布式锁进阶第一篇讲解
数据库·redis·分布式
giaz14n9X1 小时前
Redis 分布式锁进阶第六十一篇
数据库·redis·分布式
是一个Bug1 小时前
MongoDB:像搭积木一样存数据
数据库·mongodb
ULIi096kr2 小时前
MySQL解决Too many connections报错:连接数爆满排查、优化与永久解决方案
数据库·mysql·adb
SL-staff2 小时前
(一)数据源配置 —— JVS-Rules规则引擎 V2.5 操作说明介绍
数据库·jar·规则引擎·数据源·jvs-rules·api 接口·jvs低代码