被迁移 Redis 服务器必须保证没有数据 

  一、下线192.168.1.8:6379,将槽位分配给192.168.1.6:6379

redis-trib.rb reshard 172.16.1.9:6379

返回如下:

>>> Performing Cluster Check (using node 192.168.1.9:6379)
S: cf090357c5adf3b887197623c3d378a7719d44f2 192.168.1.9:6379
   slots: (0 slots) slave
   replicates 50a2fc694407fd464c201daa0e7c72146fba5507
M: c1d534ff8edbfeec70778859b8cd289ec7258de6 192.168.1.5:6380
   slots:0-1364,5461-6826,10923-12287 (4096 slots) master
   1 additional replica(s)
S: ddcc033179a02497200b5c87e2a5ee0bd1f4e2e8 192.168.1.7:6379
   slots: (0 slots) slave
   replicates eba2a74975496f8710f91b62c89afb28022df5b5
M: 50a2fc694407fd464c201daa0e7c72146fba5507 192.168.1.5:6379
   slots:6827-10922 (4096 slots) master
   1 additional replica(s)
S: 2feed5ccb782f6bc7c424f4892aafa19a57d1820 192.168.1.4:6379
   slots: (0 slots) slave
   replicates 286a966ff47d0aafa482bf121912027edf312157
S: 94e5fb4877b18f1bc1c22b4ff52e224aba6d0195 192.168.1.4:6380
   slots: (0 slots) slave
   replicates c1d534ff8edbfeec70778859b8cd289ec7258de6
M: 286a966ff47d0aafa482bf121912027edf312157 192.168.1.8:6379
   slots:1365-5460 (4096 slots) master
   1 additional replica(s)
M: eba2a74975496f8710f91b62c89afb28022df5b5 192.168.1.6:6379
   slots:12288-16383 (4096 slots) master
   1 additional replica(s)
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...

需要指定槽位往哪分1-16384,总共16384个槽位,

How many slots do you want to move (from 1 to 16384)? 4096

 接收节点ID是什么?这里写的是接受下线槽位的主机

What is the receiving node ID?eba2a74975496f8710f91b62c89afb28022df5b5

这4096的槽位是从哪个ID来的,这里写要下线的ID,这里要下线对应的ID,所以不能写all只有写done的时候才结束

Source node #1:286a966ff47d0aafa482bf121912027edf312157

  Source node #2:done

是否确定分配

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

查看信息

[16:19:10 root@localhost etc]#redis-trib.rb info 192.168.1.6:6379
192.168.1.6:6379 (eba2a749...) -> 0 keys | 8192 slots | 2 slaves.
192.168.1.8:6379 (286a966f...) -> 0 keys | 0 slots | 0 slaves.
192.168.1.5:6380 (c1d534ff...) -> 0 keys | 4096 slots | 1 slaves.
192.168.1.5:6379 (50a2fc69...) -> 0 keys | 4096 slots | 1 slaves.

集群中删除主机

redis-trib.rb del-node 192.168.1.7:6379 286a966ff47d0aafa482bf121912027edf312157
>>> Removing node 286a966ff47d0aafa482bf121912027edf312157 from cluster 192.168.1.7:6379
>>> Sending CLUSTER FORGET messages to the cluster...
>>> SHUTDOWN the node.

##前面192.168.1.7:6379指定的是当前集群中的任意一个主机的IP地址和端口,后面的ID是要删除的节点的ID