Redis的主从架构

主从模式

全量同步

  1. 首先主从同步过程第一步 会先比较replication id 判断是否是第一次同步
  2. 假设为第一次同步 那么就会 启动bgsave异步生成RDB 同时fork子进程记录生成期间的新数据
  3. 发送RDB给从节点 清空本地数据写入RDB

增量同步

  1. 对比ReplicationID不同因此选择增量同步
  2. 在Reply_Buffer中有一个环形缓冲区 以及Offset偏移量
  3. 对比完主从直接的偏移量差距后就可以选择性的获取需要增量同步的新数据
  4. 同时有一个问题 :如果超出了环形缓冲区 那么就需要进行一次全量同步在进行增量同步

哨兵模式

哨兵的主要作用:

监控、选主、通知

哨兵选选举过程:

  1. 首先通过心跳机制发Ping 如果没响应就会主观认为主节点下线
  2. 向其他Sentinel请求 进行半数选举 如果超过半数Sentinel认为节点下线就为客观下线
  3. 优先选举数据最全最合适的节点为主节点

集群模式

Cluster分片集群

分片集群将所有节点的存储分为 16384****个槽位

所有要存储的数据根据Key值进行 Hash****映射后分到具体的槽位

具体的映射算法:

Redis Cluster 是 Redis 实现"分布式+高可用"的集群方式,而 Sentinel 是在"单主结构"下提供"高可用"的方案。Cluster 更强,但也更复杂;Sentinel 更简单,但扩展性有限。

如果cluster出现故障 会自动选举主节点 故障转移 并且重新分配Hash槽位

相关推荐
时序数据说2 小时前
时序数据库市场前景分析
大数据·数据库·物联网·开源·时序数据库
勿芮介5 小时前
[微服务]ELK Stack安装与配置全指南
elk·微服务·架构
听雪楼主.6 小时前
Oracle Undo Tablespace 使用率暴涨案例分析
数据库·oracle·架构
高阳言编程6 小时前
5. 标量处理机
架构
我科绝伦(Huanhuan Zhou)6 小时前
KINGBASE集群日常维护管理命令总结
数据库·database
妖灵翎幺6 小时前
Java应届生求职八股(2)---Mysql篇
数据库·mysql
HMBBLOVEPDX6 小时前
MySQL的事务日志:
数据库·mysql
weixin_419658318 小时前
MySQL数据库备份与恢复
数据库·mysql
Jerry说前后端9 小时前
Android 组件封装实践:从解耦到架构演进
android·前端·架构
用户72278681234410 小时前
Stylet启动机制详解:从Bootstrap到View显示
架构