Redis集群指定主从关系及动态增删节点方式

 更新时间:2024年01月18日 09:57:06   作者:guotianqing  
这篇文章主要介绍了Redis集群指定主从关系及动态增删节点方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

集群创建

我们常用以下命令创建集群

redis-cli --cluster create 127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005 --cluster-replicas 1

这样就创建了一个具有3个主节点和3个从节点的集群。

其中,我们虽然指定了每个主节点都有一个从节点,但哪个是7000的从节点,却是随机分配的,直到集群创建完毕,才能确定是7003、7004还是7005。

但是,有时候,当我们只有3台物理节点时,就想要指定主从关系,从而保证高可用。

而指定主从关系,就需要手动操作了。

指定主从

思路如下

  • 先创建具有三个主节点的集群,没有从节点
  • 使用添加节点的命令添加从节点,这样就可以在添加时指定它们的主节点,建立主从对应关系

具体如下

  • 使用以下命令创建主节点:
redis-cli --cluster create 127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002 --cluster-replicas 0
  • 增加从节点:
redis-cli --cluster add-node 127.0.0.1:7003 127.0.0.1:7000 --cluster-slave --cluster-master-id ***************

其中:

  • slave 表示要添加从节点
  • cluster-master-id 要添加到哪一个主节点,id是*****
  • 127.0.0.1:7003 要添加的从节点
  • 127.0.0.1:7000 原集群中任意节点

ok,这样添加完后得到的就是指定的想要的节点架构。

动态增删节点

增加主节点

redis-cli --cluster add-node 127.0.0.1:7008 127.0.0.1:7000

其中:

127.0.0.1:7008 要向集群添加新的节点127.0.0.1:7000 原集群中任意节点

这里,节点已经加入集群,但:

由于它还没有分配到 hash slots,所以它还没有数据由于它是还没有 hash slots的主节点,所以它不会参与到从节点升级到主节点的选举中

此时,执行 resharding 指令来为它分配 hash slots,这会进入交互式命令行,由用户输入相关信息:

redis-cli --cluster reshard 127.0.0.1:7000

只需要指定一个节点,redis会自动发现其他节点。

How many slots do you want to move (from 1 to 16384)?target node id?from what nodes you want to take those keys?

  • 第一个问题需要需要填写,如1000.
  • 第二个问题可以通过命令查看:redis-cli -p 7000 cluster nodes | grep myself
  • 第三个问题:all,这样会从每个节点上移动一部分 hash slots到新节点

然后开始迁移,每迁移一个key就会输出一个点。

待所有迁移完成后,执行下面的指令查看集群是否正常:

redis-cli --cluster check 127.0.0.1:7000

增加从节点

redis-cli --cluster add-node 127.0.0.1:7006 127.0.0.1:7000 --cluster-slave

该指令与增加主节点语法一致,与添加主节点不同的是,显式指定了是从节点。

这会为该从节点随机分配一个主节点,优先从那些从节点数目最少的主节点中选取。

如果要在添加从节点时就为其指定主节点,需要指定master-id,执行下面的指令(需要替换为真实的id):

redis-cli --cluster add-node 127.0.0.1:7006 127.0.0.1:7000 --cluster-slave --cluster-master-id 3c3a0c74aae0b56170ccb03a76b60cfe7dc1912e

另一种添加从节点的方式是添加一个空的主节点,然后把该节点指定为某个主节点的从节点:

cluster replicate 3c3a0c74aae0b56170ccb03a76b60cfe7dc1912e

删除节点

注意,只能删除从节点或者空的主节点

指令如下:

redis-cli --cluster del-node 127.0.0.1:7000 <node-id>

其中:

  • 127.0.0.1:7000为集群中任意节点
  • node-id为要删除的节点的id

如果想删除有数据的主节点,必须先执行 resharding 把它的数据分配到其他节点后再删除。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Redis 如何批量设置过期时间(PIPLINE的使用)

    Redis 如何批量设置过期时间(PIPLINE的使用)

    有时候我们并不希望redis的key一直存在。例如缓存,验证码等数据,我们希望它们能在一定时间内自动的被销毁。本文就详细的介绍一下Redis 如何批量设置过期时间,感兴趣的可以了解一下
    2021-11-11
  • Windows下Redis x64的安装与使用教程详解

    Windows下Redis x64的安装与使用教程详解

    Redis是一款内存高速缓存数据库,可以满足我们对海量数据的读写需求,本文重点给大家介绍Windows下Redis x64的安装与使用教程,感兴趣的朋友一起看看吧
    2022-03-03
  • redis通过位图法记录在线用户的状态详解

    redis通过位图法记录在线用户的状态详解

    这篇文章主要给大家介绍了关于redis如何通过位图法记录在线用户的状态的相关资料,文中先对位图进行了一个简单的介绍,而后通过示例代码将实现的方法介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • redis分布式锁的go-redis实现方法详解

    redis分布式锁的go-redis实现方法详解

    这篇文章主要介绍了redis分布式锁的go-redis实现方法,本文给大家介绍的非常详细对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • 详解如何清理redis集群的所有数据

    详解如何清理redis集群的所有数据

    这篇文章主要介绍了详解如何清理redis集群的所有数据,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • 使用Docker部署Redis并配置持久化与密码保护的详细步骤

    使用Docker部署Redis并配置持久化与密码保护的详细步骤

    本文将详细介绍如何使用 Docker 部署 Redis,并通过 redis.conf 配置文件实现数据持久化和密码保护,适合在生产环境中使用,文章通过代码示例讲解的非常详细,需要的朋友可以参考下
    2025-03-03
  • redis中bind配置的详细步骤

    redis中bind配置的详细步骤

    本文主要介绍了redis中bind配置的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • 分布式爬虫处理Redis里的数据操作步骤

    分布式爬虫处理Redis里的数据操作步骤

    这篇文章主要介绍了分布式爬虫处理Redis里的数据操作步骤,数据分别存入mongodb和mysql数据库,具体内容详情及实例代码大家参考下本文
    2018-03-03
  • 浅谈Redis缓存雪崩解决方案

    浅谈Redis缓存雪崩解决方案

    本文主要介绍了Redis缓存雪崩解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • SpringBoot整合Mybatis-plus和Redis实现投票功能

    SpringBoot整合Mybatis-plus和Redis实现投票功能

    投票功能是一个非常常见的Web应用场景,这篇文章将为大家介绍一下如何将Redis和Mybatis-plus整合到SpringBoot中,实现投票功能,感兴趣的可以了解一下
    2023-05-05

最新评论