💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
- 持续学习,不断总结,共同进步,活到老学到老
- 人生的本质是追寻自我的提升,包括思想、能力、意志等等。
- 直面变化,找到背后更基础的东西,更基础的东西是用户的需求。
- 我们的成功是我们的现在和将来决定的。今天和明天已经由昨天决定,你还可以决定后天。
非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨
博客目录
21.复制信息的传递
- 概念:一个节点成为从节点,并开始复制某个主节点这一信息会通过消息发送给
集群中的其他节点
,最终集群中的所有节点都会知道某个从节点正在复制某个主节点
。 - 集群中的所有节点都会在代表主节点的
clusterNode
结构的slaves
属性和numslaves
属性中记录正在复制这个主节点的从节点名单。
struct clusterNode {
// ...
//正在复制这个主节点的从节点数量
int numslaves;
// 一个数组
//每个数组项指向一个正在复制这个主节点的从节点的clusterNode 结构
struct clusterNode **slaves;
// ...
};
22.集群故障转移
故障检查
集群中的每个节点都会定期地向集群中的其他节点发送 PING
消息,以此来检测对方是否在线,如果接收 PING
消息的节点没有在规定的时间内,向发送 PING
消息的节点返回 PONG
消息,那么发送 PING
消息的节点就会将接收 PING
消息的节点标记为疑似下线(probable fail, PFAIL )
- REDIS NODE MASTER 标识 master 节点
- REDIS NODE PFAIL 标识节点下线
故障转移
当一个从节点发现自己正在复制的主节点进入了已下线状态时,从节点将开始对下线主节点进行故障转移,以下是故障转移的执行步骤:
- 在复制下线主节点的所有从节点里面,会有一个
从节点
被选中。 - 被选中的从节点会执行
SLAVEOF no one
命令, 成为新的主节点
。 - 新的主节点会撤销所有对已下线主节点的
槽指派
,并将这些槽全部指派给自己。 - 新的主节点向集群广播一条
PONG
消息,这条PONG
消息可以让集群中的其他节点立即知道这个节点已经由从节点变成了主节点,并且这个主节点已经接管了原本由已下线节点负责处理的槽。 新的主节点
开始接收和自己负责处理的槽有关的命令请求,故障转移完成。
觉得有用的话点个赞
👍🏻
呗。
❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍
🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙