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. 配置读写分离
相关推荐
爱编程的小新☆8 分钟前
LangGraph4j工作流框架
前端·数据库·ai·langchain·langgraph4j
programhelp_20 分钟前
Google 2026 New Grad SDE VO 三轮面试详解 | 含Behavioral、Coding、Design
java·服务器·数据库
czhc114007566333 分钟前
数据库520 HALCONAN安装
数据库
阿坤带你走近大数据37 分钟前
Oracle中的OGG介绍
数据库·oracle
Ether IC Verifier39 分钟前
TCP/IP协议握手原理详解——结合以太网连接过程
服务器·网络·数据库·网络协议·tcp/ip
宋浮檀s1 小时前
SQL注入基础+DVWA搭建
数据库·sql·安全·网络安全
Amarantine、沐风倩✨1 小时前
Oracle 性能排查:通过 V$LONG_EXEC_SQLS 快速定位慢 SQL
数据库·sql·oracle
倔强的石头1061 小时前
生产环境排坑实录:SQL 标量子查询的“静默杀手”与优化器的智能推演
数据库·sql
jnrjian1 小时前
控制用户alter user 修改密码的两种办法 dbv and triggers
数据库·oracle
米高梅狮子1 小时前
01.mysql的备份与恢复
运维·数据库·mysql·docker·容器·kubernetes·github