集群扩容:增加集群的节点,槽和数据在节点之间移动。扩容集群的步骤分别为:准备新的节点、通过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这两个节点了
本文介绍了Redis集群扩容与收缩的操作。扩容需增加节点,将槽和数据在节点间移动,步骤包括准备新节点、加入集群、迁移数据等;收缩则是下线节点,要先查看节点槽数量、创建迁移槽计划,完成后下线节点并查看信息。

2806

被折叠的 条评论
为什么被折叠?



