文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Redis集群重新分片(新增/移除节点)【理论】

2024-04-02 19:55

关注

redis集群重新分片原理:(增加或移除节点)  

     

    以增加节点为例:

        我们只需要将已经分配给节点的哈希槽(hash slot),重新分配即可。

        注:hash slot重新分配时,如果槽中存在key-value,那么key-value也将一起被分配出去。

        

    例如:

        node1的哈希槽:0-5000

        node2的哈希槽:5001-10000

        node3的哈希槽:10001-16383

    现在新增node4:

    我们可以将node3的哈希槽调整为:10001-15000、node4的哈希槽:15001-16383

    也可以在三个现有节点中,各自分出一部分哈希槽,给新的节点。


    redis集群的重新分片操作是由redis的集群管理软件redis-trib负责执行的,

    但它不支持自动分片,需要自己计算从哪些节点上分配slot。

 

 redis集群在重新分片时,客户端获取数据原理:  


    重新分片时,集群不需要下线,并且源节点和目标节点都可以继续处理命令请求。

    

    在hash slot迁移过程中(一部分key-value在node3中,另一部分key-value在node4中)

    如果客户端向node3发送一个与数据库key有关的命令:

        1)node3会先在自己的数据库里面查找请求的key,

            如果找到,直接执行客户端发送的命令。

        2)如果没找到,node3给客户端返回一个ASK错误,指引客户端转向node4,

             并且客户端需要再次发送想要执行的key相关的命令。    

        3)客户端转向node4,首先发送ASKING命令,然后再次发送想要执行的key相关的命令。

             如果直接发送想要执行的key相关的命令,node4此时并不处理,

             因为key所在的槽还未迁移完,槽还属于node3,会返回错误给客户端。

             但如果先发送ASKING命令,node4在执行key相关的命令时,

             不仅会检查key所属槽是否属于自己,

             还会检查migration_slots_to数组(正在迁往自己的槽)

             判断key相关的槽是否正在迁往自己,如果是的话,则执行key相关的命令。


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯