Redis cluster集群的扩容和收缩

本文介绍了Redis集群扩容与收缩的操作。扩容需增加节点,将槽和数据在节点间移动,步骤包括准备新节点、加入集群、迁移数据等;收缩则是下线节点,要先查看节点槽数量、创建迁移槽计划,完成后下线节点并查看信息。

集群扩容:增加集群的节点,槽和数据在节点之间移动。扩容集群的步骤分别为:准备新的节点、通过cluster meet操作将节点加入集群中、将原有的数据和槽进行迁移

1、先开启6个节点以及集群

https://blog.csdn.net/vincen123/article/details/88289939

2、准备好7006,7007这两个端口的节点配置文件

######使用sed配置7006,7007端口的文件######
sed 's/7000/7006/g' redis-7000.conf > redis-7006.conf

sed 's/7000/7007/g' redis-7000.conf > redis-7007.conf

######启动这两个新的配置文件######
redis-server redis-7006.conf

redis-server redis-7007.conf

3、将7006,7007这两个节点加入到集群

######在7000节点上对这两个节点进行meet操作######
redis-cli -p 7000 cluster meet 127.0.0.1 7006

redis-cli -p 7000 cluster meet 127.0.0.1 7007

######对7006和7007设置主从关系######
redis-cli -p 7007 cluster replicate 5b68d95032c435e77ebada6f743258613b2bcd43
######在7000节点上操作,设置其为7006的从节点,所以后面的节点ID是7006的######

######查看各个节点的主从关系信息######
redis-cli -p 7000 cluster nodes

4、迁移数据

######使用redis-trib.rb工具来迁移数据######
redis-trib.rb reshard 127.0.0.1:7000

######输入迁移槽的数量,这里迁移4096个槽######
How many slots do you want to move (from   to  )?4096

######指定槽迁移的目标节点,这里用7006的节点ID######
what is the receiving node ID ? 5b68d95032c435e77ebada6f743258613b2bcd43

all
yes

5、查看7006节点的槽信息

redis-cli -p 7000 cluster nodes | grep master | grep 7006
 5b68d95032c435e77ebada6f743258613b2bcd43 127.0.0.1:7006@17006 master - 0 1551930286684 7 connected 0-1364 5461-6826 10923-12287

 

集群收缩:就是缩小这个集群,下线一些节点,然后告诉redis cluster集群的每个节点忘记这个下线的节点信息

1、先看看各个节点槽的数量

redis-cli -p 7000 cluster nodes | grep 7006
 5b68d95032c435e77ebada6f743258613b2bcd43 127.0.0.1:7006@17006 master - 0 1551930833000 7 connected 0-1364 5462-6826 10923-12287

2、创建迁移槽的计划

######创建一个迁移槽的计划,把1366个槽从7006迁移到7000节点中,这个命令在7006中执行######
redis-trib.rb reshard --from 5b68d95032c435e77ebada6f743258613b2bcd43 --to 5004860d06da1aeb4474bde7dba0cde9301cd124 --slots 1366 127.0.0.1:7006

Do you want to proceed with the proposed reshard plan (yes/no)? yes

######创建一个迁移槽的计划,把1366个槽从7006迁移到7001节点中,这个命令在7006中执行######
redis-trib.rb reshard --from 5b68d95032c435e77ebada6f743258613b2bcd43 --to 44184b66eb1e6b622b6bf45dc5c134142698498f --slots 1366 127.0.0.1:7006

Do you want to proceed with the proposed reshard plan (yes/no)? yes

######创建一个迁移槽的计划,把1365个槽从7006迁移到7002节点中,这个命令在7006中执行######
redis-trib.rb reshard --from 5b68d95032c435e77ebada6f743258613b2bcd43 --to a93846e2c63d5c224ab205b1fa5e218f7fdf5311 --slots 1365 127.0.0.1:7006

Do you want to proceed with the proposed reshard plan (yes/no)? yes

迁移槽完成后来看看7006节点的槽,已经没有了

######迁移完槽后再查看7006节点的信息,已经没有槽数了######
redis-cli -p 7000 cluster nodes | grep 7006
 5b68d95032c435e77ebada6f743258613b2bcd43 127.0.0.1:7006@17006 master - 0 1551931041015 7 connected

3、下线节点

######在7000节点中执行下线7007节点的命令,后面的节点ID是7007的节点ID信息######
redis-trib.rb del-node 127.0.0.1:7000 cf1952aff90651c717dadaa8348404d446680013

######在7000节点中执行下线7006节点的命令,后面的节点ID是7006的节点ID信息######
redis-trib.rb del-node 127.0.0.1:7000 5b68d95032c435e77ebada6f743258613b2bcd43

######先下线从节点后下线主节点是为了避免触发主从故障转移机制######

4、再次查看节点信息

redis-cli -p 7000 cluster nodes  #现在再次查看集群里各个节点的信息,已经看不到7006,7007这两个节点了

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值