相思资源网 Design By www.200059.com

前言

  本文主要是承接上一篇文章Redis集群的离线安装成功以后,我们如何进行给集群增加新的主从节点(集群扩容)以及如何从集群中删除节点(集群缩容),也就是集群的伸缩,集群伸缩的原理是控制虚拟槽和数据在节点之间进行移动,通过实际操作来整理一下集群的伸缩。

  上篇文章中搭建好的集群为三主三从,端口号为7000、7001、7002、7003、7004、7005。

  查看集群启动情况:ps -ef | grep redis

Redis集群增加节点与删除节点的方法详解

查看集群的slots分配情况以及节点之间的主从关系:

  首先登陆节点7000:redis-cli -p 7000 -h 192.168.182.132 -c //注意不要丢了-c

  cluster nodes 查看集群节点信息

Redis集群增加节点与删除节点的方法详解

  在本例中我们先增加两个节点:主节点7006和从节点7007,并给7006分配4096个slots,设置7007为7006的从节点,然后再将这两个节点从集群中删除,一定要先删除主节点,再删除从节点,要不然故障转移会生效。

一、集群的扩容

  1.准备新的节点

    在集群目录redis_cluster目录下增加redis7006和redis7007目录

    mkdir redis7006

    mkdir redis7007

    增加完成后的目录

Redis集群增加节点与删除节点的方法详解

   复制端口7000的redis.conf配置文件到redis7006和redis7007目录下,并修改配置文件中的端口为对应目录的端口号。

  例如redis7006下的redis.conf文件的内容为:

port 7006
bind 192.168.182.132 //本机IP
daemonize yes //设置为后台运行
pidfile /var/run/redis-7006.pid
cluster-enabled yes //开启集群
cluster-config-file node-7006.conf
cluster-node-timeout 15000
appendonly yes

  准备完成后,启动两个新的redis节点:

redis-server redis7006/redis.conf

redis-server redis7007/redis.conf

ps -ef | grep redis //查看新的redis节点是否启动成功

Redis集群增加节点与删除节点的方法详解

  启动以后登录7006查看节点情况:

redis-cli -p 7006 -h 192.168.182.132 -c

cluster nodes

Redis集群增加节点与删除节点的方法详解

  2.添加主节点

  (1)向集群中添加节点7006,注意一定要保证节点里面没有添加过任何数据,不然添加会报错。

 cd /usr/local/redis/redis/src

./redis-trib.rb add-node 192.168.182.132:7006 192.168.182.132:7000
 //第一次节点为新增的节点 第二个节点为集群中的节点

  添加成功:

Redis集群增加节点与删除节点的方法详解

    可以看到使用addnode命令来添加节点,第一个参数是新节点的地址,第二个参数是任意一个已经存在的节点的IP和端口. 我们可以看到新的节点已经添加到集群中:

Redis集群增加节点与删除节点的方法详解

  新节点7006现在已经连接上了集群, 成为集群的一份子, 并且可以对客户端的命令请求进行转向了, 但是和其他主节点相比, 新节点还有两点区别:

新节点没有包含任何数据, 因为它没有包含任何哈希槽.尽管新节点没有包含任何哈希槽, 但它仍然是一个主节点, 所以在集群需要将某个从节点升级为新的主节点时, 这个新节点不会被选中。

    接下来, 只要使用 redis-trib 程序, 将集群中的某些哈希桶移动到新节点里面, 新节点就会成为真正的主节点了。

    (2)为主节点7006分配虚拟槽

cd /usr/local/redis/redis/src

./redis-trib.rb reshard 192.168.182.132:7001 //可以为任意的节点 在此登录的7001只是作为客户端去访问的

Redis集群增加节点与删除节点的方法详解

执行后:

  因为我们增加7006为主节点后,一共存在四个主节点,为了平均分配我们需要给7006分配16384除以4等于4096个节点,所以我们输入4096,按enter继续:

Redis集群增加节点与删除节点的方法详解

  输入7006的节点ID,按enter继续:

Redis集群增加节点与删除节点的方法详解

  从哪些主节点抽取槽到新节点中:all为所有主节点,done:指定节点,在这里我们输入all,按enter继续:

Redis集群增加节点与删除节点的方法详解

  输入yes后按enter开始给7006分配虚拟槽,分配完成后:

Redis集群增加节点与删除节点的方法详解

    登录集群查看一下集群的状态:

redis-cli -p 7000 -h 192.168.182.132 -c

cluster nodes

Redis集群增加节点与删除节点的方法详解

    至此主节点已经添加完毕了,我们的集群由三主三从变成了四主三从。

  3.添加从节点7007

   (1)使用add-node添加新节点

 cd /usr/local/redis/redis/src

./redis-trib.rb add-node 192.168.182.132:7007 192.168.182.132:7000
 //第一次节点为新增的节点 第二个节点为集群中的节点

  加入集群成功,登录到集群中查看一下集群状态:

Redis集群增加节点与删除节点的方法详解

  7007还是一个Master节点,而且没有拥有自己的slot槽。那么我们接下来要让它变成从节点。

  (2)将7007变为7006的 从节点

   使用CLUSTER REPLICATE 命令改变一个从节点的主节点。

redis-cli -p 7007 -h 192.168.182.132

cluster replicate 52d169e7011ccdf10f99c1d83f92409dcc37ab55 //后面的字符串为节点7006的节点ID

  设置成功后查看一下:

Redis集群增加节点与删除节点的方法详解

    集群的从节点7007添加成功。

二、集群的缩容

  只要使用del-node命令即可:

./redis-trib del-node 127.0.0.1:7000 <node-id>
第一个参数是任意一个节点的地址,第二个节点是你想要移除的节点地址。

使用同样的方法移除主节点,不过在移除主节点前,需要确保这个主节点是空的. 如果不是空的,需要将这个节点的数据重新分片到其他主节点上.

替代移除主节点的方法是手动执行故障恢复,被移除的主节点会作为一个从节点存在,不过这种情况下不会减少集群节点的数量,也需要重新分片数据.[/code]

  1.删除从节点

   删除节点用del-node命令。此命令需要制定删除节点的ip和端口,以及节点的id。

cd /usr/local/redis/redis/src

./redis-trib.rb del-node 192.168.182.132:7007 7007节点ID

  删除成功后:

Redis集群增加节点与删除节点的方法详解

  删除后我们再次查看集群的节点信息,如下所示,7007从节点已经被移除掉。

Redis集群增加节点与删除节点的方法详解

  2.删除主节点

  (1)将主节点7006的slots分配到其他主节点上

  cd /usr/local/redis/redis/src

  ./redis-trib.rb reshard 192.168.182.132:7006

Redis集群增加节点与删除节点的方法详解

    选择完这几项以后,回车继续:

Redis集群增加节点与删除节点的方法详解

    输入yes,表示接受这个计划,然后回车,完成7006节点的槽的移除。

    登录集群查看当前集群情况:

Redis集群增加节点与删除节点的方法详解

    节点7006上没有任何槽。

  (2)使用del-node命令来删除7006主节点。

cd /usr/local/redis/redis/src

./redis-trib.rb del-node 192.168.182.132:7006 52d169e7011ccdf10f99c1d83f92409dcc37ab55

  删除成功:

Redis集群增加节点与删除节点的方法详解

  最后登录查看集群又恢复到了三主三从的结构了,只是从刚开始的均匀分配变成了7000端口的主节点多了4096个slots。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。

标签:
redis集群节点,redis集群增加节点

相思资源网 Design By www.200059.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
相思资源网 Design By www.200059.com

评论“Redis集群增加节点与删除节点的方法详解”

暂无Redis集群增加节点与删除节点的方法详解的评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。