Redis Cluster集群架构实现

Redis集群简介

通过前面三篇博客的介绍《Redis基础认识及常用命令使用(一)–技术流ken》,《Redis基础知识补充及持久化、备份介绍(二)–技术流ken》,《Redis主从复制、多实例、高可用(三)–技术流ken》,现在已经对redis的基础知识,常用命令,持久化,备份,主从复制,多实例的安装以及redis的高可用熟练掌握了。本篇博客将介绍redis cluster集群,也是一个比较复杂的内容,本篇博客将采用较为简洁的方式来呈现redis集群。

有关redis集群的介绍可以参考下面我摘自redis官网的简介。

Redis 集群是一个可以在多个 Redis 节点之间进行数据共享的设施(installation)。

Redis 集群不支持那些需要同时处理多个键的 Redis 命令, 因为执行这些命令需要在多个 Redis 节点之间移动数据, 并且在高负载的情况下, 这些命令将降低 Redis 集群的性能, 并导致不可预测的行为。

Redis 集群通过分区(partition)来提供一定程度的可用性(availability): 即使集群中有一部分节点失效或者无法进行通讯, 集群也可以继续处理命令请求。

Redis 集群提供了以下两个好处:

  • 将数据自动切分(split)到多个节点的能力。
  • 当集群中的一部分节点失效或者无法进行通讯时, 仍然可以继续处理命令请求的能力。  –摘自redis官网

总而言之,redis集群实现了数据的共享以及去中心化。

 

Redis集群实现

实现redis集群,现在采用一台服务器安装6个redis实例,有关如果安装多实例的详细讲解请参考我上篇博客《Redis主从复制、多实例、高可用(三)–技术流ken

6个多实例,三个为主节点,三个为从节点

环境:

CentOS Linux release 7.5.1804 (Core)

redis-4.0.11

 

创建多实例

第一步:创建多实例数据目录

root@ken ~]# mkdir /ken
[root@ken ~]# cd /ken
[root@ken ken]# mkdir 6379 6380 6381 6382 6383 6384
[root@ken ken]# ls
6379  6380  6381  6382  6383  6384

 

第二步:上传redis安装包

这里使用的是redis-4.0.11的版本,可以在redis官方网站进行下载https://redis.io/

[root@ken ~]# rz

 

第三步:解压安装包

[root@ken ~]# tar xf redis-4.0.11.tar.gz

 

第四步:复制解压安装包的配置文件到6379目录下

[root@ken ~]# cp redis-4.0.11/redis.conf /ken/6379/

 

第五步:移动redis解压包至/usr/local/redis下

[root@ken ~]# mv redis-4.0.11 /usr/local/redis

 

第六步:编译安装

[root@ken ~]# cd /usr/local/redis
[root@ken redis]# make && make install
[root@ken ~]# ln /usr/local/redis/src/ /bin -s

 

第七步:修改配置文件

复制代码
[root@ken ~]# grep -E -v "^#|^$" /ken/6379/redis.conf
bind 10.220.5.137       #绑定本机ip地址
protected-mode yes
port 6379               #监听端口
tcp-backlog 511
timeout 0
tcp-keepalive 300
daemonize yes           #后台运行
supervised no
pidfile /ken/6379/redis_6379.pid  #pid文件保存位置
loglevel notice
logfile ""
databases 16
always-show-logo yes
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
dir /ken/6379/            #rdb文件保存位置
slave-serve-stale-data yes
slave-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-disable-tcp-nodelay no
slave-priority 100
lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
slave-lazy-flush no
appendonly no
appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-load-truncated yes
aof-use-rdb-preamble no
lua-time-limit 5000
cluster-enabled yes    #开启集群
cluster-config-file nodes-6379.conf  #集群文件名称
cluster-node-timeout 15000           #集群超时时间
slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
aof-rewrite-incremental-fsync yes
复制代码

 

第八步:把上面这个修改过的文件复制到其他的实例数据目录之下

[root@ken ~]# cp /ken/6379/redis.conf /ken/6380/
[root@ken ~]# cp /ken/6379/redis.conf /ken/6381/
[root@ken ~]# cp /ken/6379/redis.conf /ken/6382/
[root@ken ~]# cp /ken/6379/redis.conf /ken/6383/
[root@ken ~]# cp /ken/6379/redis.conf /ken/6384/

 

第九步:修改配置文件

只要使用sed即可进行修改

[root@ken ~]# sed -i 's/6379/6380/g' /ken/6380/redis.conf 
[root@ken ~]# sed -i 's/6379/6381/g' /ken/6381/redis.conf 
[root@ken ~]# sed -i 's/6379/6382/g' /ken/6382/redis.conf 
[root@ken ~]# sed -i 's/6379/6383/g' /ken/6383/redis.conf 
[root@ken ~]# sed -i 's/6379/6384/g' /ken/6384/redis.conf

 

第十步:启动各个实例

复制代码
[root@ken ~]# redis-server /ken/6380/redis.conf 
[root@ken ~]# redis-server /ken/6381/redis.conf 
[root@ken ~]# redis-server /ken/6382/redis.conf 
[root@ken ~]# redis-server /ken/6383/redis.conf 
[root@ken ~]# redis-server /ken/6384/redis.conf 
[root@ken ~]# ss -tnl
State      Recv-Q Send-Q                   Local Address:Port                                  Peer Address:Port              
LISTEN     0      128                       10.220.5.137:16380                                            *:*                  
LISTEN     0      128                       10.220.5.137:16381                                            *:*                  
LISTEN     0      128                       10.220.5.137:16382                                            *:*                  
LISTEN     0      128                       10.220.5.137:16383                                            *:*                  
LISTEN     0      128                       10.220.5.137:16384                                            *:*                  
LISTEN     0      128                                  *:10050                                            *:*                  
LISTEN     0      128                                  *:10051                                            *:*                  
LISTEN     0      128                       10.220.5.137:6379                                             *:*                  
LISTEN     0      128                       10.220.5.137:6380                                             *:*                  
LISTEN     0      128                       10.220.5.137:6381                                             *:*                  
LISTEN     0      128                       10.220.5.137:6382                                             *:*                  
LISTEN     0      128                       10.220.5.137:6383                                             *:*                  
LISTEN     0      128                                  *:111                                              *:*                  
LISTEN     0      128                       10.220.5.137:6384                                             *:*                  
LISTEN     0      128                                  *:22                                               *:*                  
LISTEN     0      128                       10.220.5.137:16379                                            *:*                  
LISTEN     0      128                                 :::10050                                           :::*                  
LISTEN     0      128                                 :::10051                                           :::*                  
LISTEN     0      70                                  :::3306                                            :::*                  
LISTEN     0      128                                 :::111                                             :::*                  
LISTEN     0      128                                 :::80                                              :::*                  
LISTEN     0      128                                 :::22                                              :::*
复制代码

 

安装ruby2.3

实现redis cluster功能,依赖redis-trib.rb,而这个工具是依赖一个ruby开发工具包的,所以需要安装ruby环境,并安装依赖包

 

第一步:上传解压安装包

[root@ken ~]# rz
[root@ken ~]# tar xf ruby-2.3.5.tar.gz

 

第二步:编译安装

建议虚拟机内存至少1个G以上

[root@ken ~]# cd ruby-2.3.5/
[root@ken ruby-2.3.5]# ./configure --prefix=/usr/local/ruby && make && make install

 

第三步:安装redis-trib.rb的依赖

复制代码
[root@ken ~]# ln -s /usr/local/ruby/bin/gem /bin
[root@ken ~]# gem install -l redis-3.3.0.gem 
Successfully installed redis-3.3.0
Parsing documentation for redis-3.3.0
Installing ri documentation for redis-3.3.0
Done installing documentation for redis after 0 seconds
1 gem installed
[root@ken ~]# ln -s /usr/local/ruby/bin/ruby  /bin
复制代码

 

获取集群帮助

只需要输入redis-trib.rb回车即可

复制代码
[root@ken ~]# redis-trib.rb 
Usage: redis-trib <command> <options> <arguments ...>

  create          host1:port1 ... hostN:portN
                  --replicas <arg>
  check           host:port
  info            host:port
  fix             host:port
                  --timeout <arg>
  reshard         host:port
                  --from <arg>
                  --to <arg>
                  --slots <arg>
                  --yes
                  --timeout <arg>
                  --pipeline <arg>
  rebalance       host:port
                  --weight <arg>
                  --auto-weights
                  --use-empty-masters
                  --timeout <arg>
                  --simulate
                  --pipeline <arg>
                  --threshold <arg>
  add-node        new_host:new_port existing_host:existing_port
                  --slave
                  --master-id <arg>
  del-node        host:port node_id
  set-timeout     host:port milliseconds
  call            host:port command arg arg .. arg
  import          host:port
                  --from <arg>
                  --copy
                  --replace
  help            (show this help)

For check, fix, reshard, del-node, set-timeout you can specify the host and port of any working node in the cluster.
复制代码

 

创建redis集群

命令的意义如下:

  • 给定 redis-trib.rb 程序的命令是 create , 这表示我们希望创建一个新的集群。
  • 选项 --replicas 1 表示我们希望为集群中的每个主节点创建一个从节点。
  • 之后跟着的其他参数则是实例的地址列表, 我们希望程序使用这些地址所指示的实例来创建新集群。

简单来说, 以上命令的意思就是让 redis-trib 程序创建一个包含三个主节点和三个从节点的集群。

接着, redis-trib 会打印出一份预想中的配置给你看, 如果你觉得没问题的话, 就可以输入 yes , redis-trib 就会将这份配置应用到集群当中:

复制代码
[root@ken ~]# redis-trib.rb create --replicas 1 10.220.5.137:6379 10.220.5.137:6380 10.220.5.137:6381 10.220.5.137:6382 10.220.5.137:6383 10.220.5.137:6384
>>> Creating cluster
>>> Performing hash slots allocation on 6 nodes...
Using 3 masters:
10.220.5.137:6379
10.220.5.137:6380
10.220.5.137:6381
Adding replica 10.220.5.137:6383 to 10.220.5.137:6379
Adding replica 10.220.5.137:6384 to 10.220.5.137:6380
Adding replica 10.220.5.137:6382 to 10.220.5.137:6381
>>> Trying to optimize slaves allocation for anti-affinity
[WARNING] Some slaves are in the same host as their master
M: 57753754f4c89054ab14e8ec517604c4fc4c8ed5 10.220.5.137:6379
   slots:0-5460 (5461 slots) master
M: 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d 10.220.5.137:6380
   slots:5461-10922 (5462 slots) master
M: ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8 10.220.5.137:6381
   slots:10923-16383 (5461 slots) master
S: 1bc40ffc4c54099f8cf47efdeb82a9f42e717bf6 10.220.5.137:6382
   replicates 57753754f4c89054ab14e8ec517604c4fc4c8ed5
S: 640bb3a62565a0bb74980852fee7e8636cf238bc 10.220.5.137:6383
   replicates 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d
S: b8214c9e4b617c7992e71a2fa07a4a64cfeddf58 10.220.5.137:6384
   replicates ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8
Can I set the above configuration? (type 'yes' to accept): yes   #输入yes
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join.....
>>> Performing Cluster Check (using node 10.220.5.137:6379)
M: 57753754f4c89054ab14e8ec517604c4fc4c8ed5 10.220.5.137:6379
   slots:0-5460 (5461 slots) master
   1 additional replica(s)
M: ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8 10.220.5.137:6381
   slots:10923-16383 (5461 slots) master
   1 additional replica(s)
M: 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d 10.220.5.137:6380
   slots:5461-10922 (5462 slots) master
   1 additional replica(s)
S: 640bb3a62565a0bb74980852fee7e8636cf238bc 10.220.5.137:6383
   slots: (0 slots) slave
   replicates 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d
S: b8214c9e4b617c7992e71a2fa07a4a64cfeddf58 10.220.5.137:6384
   slots: (0 slots) slave
   replicates ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8
S: 1bc40ffc4c54099f8cf47efdeb82a9f42e717bf6 10.220.5.137:6382
   slots: (0 slots) slave
   replicates 57753754f4c89054ab14e8ec517604c4fc4c8ed5
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
复制代码

 

Redis集群测试

测试 Redis 集群比较简单的办法就是使用 redis-rb-cluster 或者 redis-cli , 接下来将使用 redis-cli 为例来进行演示:

 

第一步:登录集群中

一定要加个-c,后面输入哪个端口都可以,这就是redis的区中心化思想

[root@ken ~]# redis-cli -c -h 10.220.5.137 -p 6379

 

第二步:创建key

可以发现创建的key被分配到了不同的节点

复制代码
10.220.5.137:6379> keys *
(empty list or set)
10.220.5.137:6379> set name ken
-> Redirected to slot [5798] located at 10.220.5.137:6380
OK
10.220.5.137:6380> set addr jiangsu
-> Redirected to slot [12790] located at 10.220.5.137:6381
OK
10.220.5.137:6381> set tel 123445
-> Redirected to slot [7485] located at 10.220.5.137:6380
OK
10.220.5.137:6380> set ege 25
OK
10.220.5.137:6380> set gender male
-> Redirected to slot [15355] located at 10.220.5.137:6381
OK
10.220.5.137:6381> keys *
1) "addr"
2) "gender"
复制代码

 

第三步:获取key

在端口6381的节点之上没有tel这个key,但是我们仍然可以使用get tel获取到值,这就实现了redis集群的数据共享

10.220.5.137:6381> keys *
1) "addr"
2) "gender"
10.220.5.137:6381> get tel
-> Redirected to slot [7485] located at 10.220.5.137:6380
"123445"

 

在集群中添加新的节点

第一步:创建一个新的实例

复制代码
[root@ken ~]# mkdir /ken/6385
[root@ken ~]# cp /ken/6379/redis.conf /ken/6385/
[root@ken ~]# sed -i 's/6379/6385/g' /ken/6385/redis.conf 
[root@ken ~]# redis-server /ken/6385/redis.conf
10461:C 15 Nov 21:21:11.646 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
10461:C 15 Nov 21:21:11.646 # Redis version=4.0.11, bits=64, commit=00000000, modified=0, pid=10461, just started
10461:C 15 Nov 21:21:11.646 # Configuration loaded
复制代码

 

第二步:添加该节点到集群中

命令中的 add-node 表示我们要让 redis-trib 将一个节点添加到集群里面, add-node 之后跟着的是新节点的 IP 地址和端口号, 再之后跟着的是集群中任意一个已存在节点的 IP 地址和端口号, 这里我们使用的是 10.220.5.137:6379 。

复制代码
[root@ken ~]# redis-trib.rb add-node 10.220.5.137:6385 10.220.5.137:6379
>>> Adding node 10.220.5.137:6385 to cluster 10.220.5.137:6379
>>> Performing Cluster Check (using node 10.220.5.137:6379)
M: 57753754f4c89054ab14e8ec517604c4fc4c8ed5 10.220.5.137:6379
   slots:0-5460 (5461 slots) master
   1 additional replica(s)
M: ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8 10.220.5.137:6381
   slots:10923-16383 (5461 slots) master
   1 additional replica(s)
M: 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d 10.220.5.137:6380
   slots:5461-10922 (5462 slots) master
   1 additional replica(s)
S: 640bb3a62565a0bb74980852fee7e8636cf238bc 10.220.5.137:6383
   slots: (0 slots) slave
   replicates 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d
S: b8214c9e4b617c7992e71a2fa07a4a64cfeddf58 10.220.5.137:6384
   slots: (0 slots) slave
   replicates ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8
S: 1bc40ffc4c54099f8cf47efdeb82a9f42e717bf6 10.220.5.137:6382
   slots: (0 slots) slave
   replicates 57753754f4c89054ab14e8ec517604c4fc4c8ed5
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
>>> Send CLUSTER MEET to node 10.220.5.137:6385 to make it join the cluster.
[OK] New node added correctly.
复制代码

 

第三步:查看

通过 cluster nodes 命令, 我们可以确认新节点10.220.5.137:6385 已经被添加到集群里面了

复制代码
10.220.5.137:6379> CLUSTER nodes
57753754f4c89054ab14e8ec517604c4fc4c8ed5 10.220.5.137:6379@16379 myself,master - 0 1542288244000 1 connected 0-5460
daf9464ef45d0c73e1ee18f7cc7ddbc7d9719f2d 10.220.5.137:6385@16385 master - 0 1542288242824 0 connected
ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8 10.220.5.137:6381@16381 master - 0 1542288244000 3 connected 10923-16383
3a9aa9592afc594c7e4206cc82ffb37d46a5b23d 10.220.5.137:6380@16380 master - 0 1542288242000 2 connected 5461-10922
640bb3a62565a0bb74980852fee7e8636cf238bc 10.220.5.137:6383@16383 slave 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d 0 1542288242000 5 connected
b8214c9e4b617c7992e71a2fa07a4a64cfeddf58 10.220.5.137:6384@16384 slave ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8 0 1542288244852 6 connected
1bc40ffc4c54099f8cf47efdeb82a9f42e717bf6 10.220.5.137:6382@16382 slave 57753754f4c89054ab14e8ec517604c4fc4c8ed5 0 1542288243844 4 connected
复制代码

 

第四步:使添加的新节点为从节点

如果我们打算让新节点成为 10.220.5.137:6379 的从节点, 那么我们只要用客户端连接上新节点, 然后执行以下命令就可以了

[root@ken ~]# redis-cli -c -h 10.220.5.137 -p 6385
10.220.5.137:6385> CLUSTER REPLICATE 57753754f4c89054ab14e8ec517604c4fc4c8ed5
OK
其中57753754f4c89054ab14e8ec517604c4fc4c8ed5是主节点10.220.5.137:6379的id

对redis中的数据做重新分片

 

[root@ken ~]# redis-trib.rb reshard 10.220.5.137:6379

 

你只需要指定集群中其中一个节点的地址, redis-trib 就会自动找到集群中的其他节点。

 

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

我们将打算移动的槽数量设置为 1000 个。

 

What is the receiving node ID? 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d

定目标需要使用节点的 ID , 而不是 IP 地址和端口。 比如说, 我们打算使用集群的第一个主节点来作为目标, 它的 IP 地址和端口是 10.220.5.137:6380 , 而节点 ID 则是3a9aa9592afc594c7e4206cc82ffb37d46a5b23d , 那么我们应该向 redis-trib 提供节点的 ID

 

Source node #1:ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8

接着, redis-trib 会向你询问重新分片的源节点(source node), 也即是, 要从哪个节点中取出 1000 个哈希槽, 并将这些槽移动到目标节点上面。

 

Source node #2:done
Do you want to proceed with the proposed reshard plan (yes/no)? yes

输入 yes 并使用按下回车之后, redis-trib 就会正式开始执行重新分片操作, 将指定的哈希槽从源节点一个个地移动到目标节点上面

 

复制代码
Moving slot 12905 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12906 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12907 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12908 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12909 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12910 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12911 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12912 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12913 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12914 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12915 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12916 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12917 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12918 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12919 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12920 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12921 from 10.220.5.137:6381 to 10.220.5.137:6380: 
Moving slot 12922 from 10.220.5.137:6381 to 10.220.5.137:6380:
复制代码

在重新分片操作执行完毕之后, 可以使用以下命令来检查集群是否正常

复制代码
[root@ken ~]# redis-trib.rb check 10.220.5.137:6379
>>> Performing Cluster Check (using node 10.220.5.137:6379)
M: 57753754f4c89054ab14e8ec517604c4fc4c8ed5 10.220.5.137:6379
   slots:0-5460 (5461 slots) master
   2 additional replica(s)
S: daf9464ef45d0c73e1ee18f7cc7ddbc7d9719f2d 10.220.5.137:6385
   slots: (0 slots) slave
   replicates 57753754f4c89054ab14e8ec517604c4fc4c8ed5
M: ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8 10.220.5.137:6381
   slots:12923-16383 (3461 slots) master
   1 additional replica(s)
M: 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d 10.220.5.137:6380
   slots:5461-12922 (7462 slots) master
   1 additional replica(s)
S: 640bb3a62565a0bb74980852fee7e8636cf238bc 10.220.5.137:6383
   slots: (0 slots) slave
   replicates 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d
S: b8214c9e4b617c7992e71a2fa07a4a64cfeddf58 10.220.5.137:6384
   slots: (0 slots) slave
   replicates ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8
S: 1bc40ffc4c54099f8cf47efdeb82a9f42e717bf6 10.220.5.137:6382
   slots: (0 slots) slave
   replicates 57753754f4c89054ab14e8ec517604c4fc4c8ed5
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
复制代码

 

删除节点

如果节点中有slot,那么需要先将slot 执行reshard给其他节点,然后才能执行删除操作

1. 删除空slot

删除10.220.5.137:6385

复制代码
[root@ken ~]# redis-trib.rb check 10.220.5.137:6379
>>> Performing Cluster Check (using node 10.220.5.137:6379)
M: 57753754f4c89054ab14e8ec517604c4fc4c8ed5 10.220.5.137:6379
   slots:0-5460 (5461 slots) master
   2 additional replica(s)
S: daf9464ef45d0c73e1ee18f7cc7ddbc7d9719f2d 10.220.5.137:6385
   slots: (0 slots) slave
   replicates 57753754f4c89054ab14e8ec517604c4fc4c8ed5
M: ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8 10.220.5.137:6381
   slots:12923-16383 (3461 slots) master
   1 additional replica(s)
...
复制代码

执行如下命令

[root@ken ~]# redis-trib.rb del-node 10.220.5.137:6379 daf9464ef45d0c73e1ee18f7cc7ddbc7d9719f2d
>>> Removing node daf9464ef45d0c73e1ee18f7cc7ddbc7d9719f2d from cluster 10.220.5.137:6379
>>> Sending CLUSTER FORGET messages to the cluster...
>>> SHUTDOWN the node.

查看发现6385节点已经被移除

复制代码
[root@ken ~]# redis-trib.rb check 10.220.5.137:6379
>>> Performing Cluster Check (using node 10.220.5.137:6379)
M: 57753754f4c89054ab14e8ec517604c4fc4c8ed5 10.220.5.137:6379
   slots:0-5460 (5461 slots) master
   1 additional replica(s)
M: ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8 10.220.5.137:6381
   slots:12923-16383 (3461 slots) master
   1 additional replica(s)
M: 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d 10.220.5.137:6380
   slots:5461-12922 (7462 slots) master
   1 additional replica(s)
S: 640bb3a62565a0bb74980852fee7e8636cf238bc 10.220.5.137:6383
   slots: (0 slots) slave
   replicates 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d
S: b8214c9e4b617c7992e71a2fa07a4a64cfeddf58 10.220.5.137:6384
   slots: (0 slots) slave
   replicates ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8
S: 1bc40ffc4c54099f8cf47efdeb82a9f42e717bf6 10.220.5.137:6382
   slots: (0 slots) slave
   replicates 57753754f4c89054ab14e8ec517604c4fc4c8ed5
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
复制代码

 

2.删除带有slot的节点
提示有数据报错
[root@ken ~]# redis-trib.rb del-node 10.220.5.137:6379 ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8
>>> Removing node ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8 from cluster 10.220.5.137:6379
[ERR] Node 10.220.5.137:6381 is not empty! Reshard data away and try again.

需要重新分片

复制代码
[root@ken ~]# redis-trib.rb reshard 10.220.5.137:6379
>>> Performing Cluster Check (using node 10.220.5.137:6379)
M: 57753754f4c89054ab14e8ec517604c4fc4c8ed5 10.220.5.137:6379
   slots:0-5460 (5461 slots) master
   1 additional replica(s)
M: ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8 10.220.5.137:6381
   slots:12923-16383 (3461 slots) master
   1 additional replica(s)
M: 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d 10.220.5.137:6380
   slots:5461-12922 (7462 slots) master
   1 additional replica(s)
S: 640bb3a62565a0bb74980852fee7e8636cf238bc 10.220.5.137:6383
   slots: (0 slots) slave
   replicates 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d
S: b8214c9e4b617c7992e71a2fa07a4a64cfeddf58 10.220.5.137:6384
   slots: (0 slots) slave
   replicates ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8
S: 1bc40ffc4c54099f8cf47efdeb82a9f42e717bf6 10.220.5.137:6382
   slots: (0 slots) slave
   replicates 57753754f4c89054ab14e8ec517604c4fc4c8ed5
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
How many slots do you want to move (from 1 to 16384)? 3461
What is the receiving node ID? 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d
Please enter all the source node IDs.
  Type 'all' to use all the nodes as source nodes for the hash slots.
  Type 'done' once you entered all the source nodes IDs.
Source node #1:ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8
Source node #2:done
复制代码

再检查slot已经为空

复制代码
>>> Performing Cluster Check (using node 10.220.5.137:6379)
M: 57753754f4c89054ab14e8ec517604c4fc4c8ed5 10.220.5.137:6379
   slots:0-5460 (5461 slots) master
   1 additional replica(s)
M: ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8 10.220.5.137:6381  #已经为空
   slots: (0 slots) master
   0 additional replica(s)
M: 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d 10.220.5.137:6380
   slots:5461-16383 (10923 slots) master
   2 additional replica(s)
S: 640bb3a62565a0bb74980852fee7e8636cf238bc 10.220.5.137:6383
   slots: (0 slots) slave
   replicates 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d
S: b8214c9e4b617c7992e71a2fa07a4a64cfeddf58 10.220.5.137:6384
   slots: (0 slots) slave
   replicates 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d
S: 1bc40ffc4c54099f8cf47efdeb82a9f42e717bf6 10.220.5.137:6382
   slots: (0 slots) slave
   replicates 57753754f4c89054ab14e8ec517604c4fc4c8ed5
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
复制代码

再执行删除操作

[root@ken ~]# redis-trib.rb del-node 10.220.5.137:6379 ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8
>>> Removing node ffadc66b51b6c87ad3c5a33dc9ec39f984bb80e8 from cluster 10.220.5.137:6379
>>> Sending CLUSTER FORGET messages to the cluster...
>>> SHUTDOWN the node.

再次查看。6381节点已经被删除

复制代码
[root@ken ~]# redis-trib.rb check 10.220.5.137:6379
>>> Performing Cluster Check (using node 10.220.5.137:6379)
M: 57753754f4c89054ab14e8ec517604c4fc4c8ed5 10.220.5.137:6379
   slots:0-5460 (5461 slots) master
   1 additional replica(s)
M: 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d 10.220.5.137:6380
   slots:5461-16383 (10923 slots) master
   2 additional replica(s)
S: 640bb3a62565a0bb74980852fee7e8636cf238bc 10.220.5.137:6383
   slots: (0 slots) slave
   replicates 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d
S: b8214c9e4b617c7992e71a2fa07a4a64cfeddf58 10.220.5.137:6384
   slots: (0 slots) slave
   replicates 3a9aa9592afc594c7e4206cc82ffb37d46a5b23d
S: 1bc40ffc4c54099f8cf47efdeb82a9f42e717bf6 10.220.5.137:6382
   slots: (0 slots) slave
   replicates 57753754f4c89054ab14e8ec517604c4fc4c8ed5
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
posted @ 2019-08-22 13:44  openstack彭  阅读(402)  评论(0编辑  收藏  举报