redis集群实现(二)集群添加节点

本文介绍了Redis集群中添加节点的步骤和原理,包括客户端通过`cluster meet`命令、节点间的握手过程、数据结构创建以及Gossip协议在节点传播中的作用。深入解析了`clusterCommand`、`clusterStartHandshake`、`createClusterNode`、`clusterAddNode`等关键函数的实现,揭示了MEET消息的发送与接收机制。
摘要由CSDN通过智能技术生成

redis-3.0.0里,集群添加节点是通过客户端运行cluster meet命令来实现的,命令格式是cluster meet <ip> <port>,如果客户端向A节点发送这条命令,ipport分别是B节点的ipport,就会把ip:port的机器添加进入执行命令的节点所在的集群里。

具体的流程如下:

1.首先客户端向A节点发送cluster meet <ip> <port>命令。

2.A节点在本地为B节点创建对应的数据结构,然后向B节点发送meet命令。

3.B节点在本地为A节点创建相应的数据结构,并向A节点发送PONG消息,表示收到A节点的消息。

4.A节点收到PONG以后,向B节点返回PING消息。

5.A节点通过Gossip协议向集群中的其他节点传播,一段时间以后,集群中所有的节点都会知道B

如图:


理解了原理了以后,我们就来看一看redis-3.0.0里对于cluster meet命令以及后续的过程的代码实现,以便于更加深入的理解redis

redismeet命令的定义是clusterCommand函数,我们看看clusterCommand函数对于meet的实现。

void clusterCommand(redisClient *c) {
    // 不能在非集群模式下使用该命令
    if (server.cluster_enabled == 0) { 
        addReplyError(c,"This instance has cluster support disabled");
        return;
    }    
//匹配命令ÿ
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值