Redis(设计与实现):53---集群之在集群中执行命令

一、在集群中执行命令

  • 在对数据库中的16384个槽都进行了指派之后,集群就会进入上线状态,这时客户端就可以向集群中的节点发送数据命令

二、判断执行键所属槽

  • 当客户端向节点发送与数据库键有关的命令时,接收命令的节点会计算出命令要处理的数据库键属于哪个槽,并检查这个槽是否指派给了自己:
    • 如果键所在的槽正好就指派给了当前节点,那么节点直接执行这个命令
    • 如果键所在的槽并没有指派给当前节点,那么节点会向客户端返回一个MOVED错误, 指引客户端转向(redirect)至正确的节点,并再次发送之前想要执行的命令
  • 下图展示了这两种情况的判断流程:

三、演示案例

  • 举个例子,如果我们在之前提到的,由7000、7001、7002三个节点组成的集群中,用客户端连上节点7000,并发送以下命令,键date所在的槽2022正是由节点7000负责处理的,那么命令会直接被节点7000执行:

  • 但是,如果我们执行以下命令,那么客户端会先被转向至节点7001,然后再执行命令:

  • 这是因为键msg所在的槽6257是由节点7001负责处理的,而不是由最初接收命令的节点 7000负责处理:
    • 当客户端第一次向节点7000发送SET命令的时候,节点7000会向客户端返回MOVED错误,指引客户端转向至节点7001
    • 当客户端转向到节点7001之后,客户端重新向节点7001发送SET命令,这个命令会被节点7001成功执行

四、计算键所属槽、判断槽所属节点、MOVED错误

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

董哥的黑板报

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值