Redis集群管理:在线伸缩扩展、故障转移

实验环境

主机名        IP              端口
node1    192.168.14.210    7001、8001
node2    192.168.14.211    7002、8002
node3    192.168.14.212    7003、8003

前提:已经部署集群,查看https://blog.csdn.net/tladagio/article/details/103580641

一、增加节点

1、根据上篇文章在node4新增一个节点,然后启动redis

[root@node4 ~]# redis-server /usr/local/redis/cluster/redis_7004.conf 
[root@node4 ~]# redis-server /usr/local/redis/cluster/redis_8004.conf

2、新增一个master节点7004(add-node       new_host:new_port existing_host:existing_port)

[root@node4 ~]# redis-cli -a 123456 --cluster add-node 192.168.14.216:7004 192.168.14.210:7001

3、node1查看集群状态,

当添加节点成功以后,新增的节点不会有任何数据,因为它没有分配任何的slot(hash槽)。我们需要为新节点手工分配slot。

4、给node4分配slot槽

[root@node1 ~]# redis-cli -a 123456 --cluster reshard 192.168.14.216:7004

5、node1节点再次查看集群状态

6、新增一个slave节点8004

[root@node1 ~]# redis-cli -a 123456 --cluster add-node 192.168.14.216:8004 192.168.14.210:7001 --cluster-slave

7、查看集群状态

二、删除节点

不能直接删除有数据的master节点,因为主节点的里面分配了slot 槽,所以我们这里必须先把7004里的slot 槽放入到其他的可用主节点中去,然后再进行移除节点操作才行,不然会出现数据丢失问题

1、在删除node4的master节点之前,先把数据移走

[root@node1 ~]# redis-cli -a 123456 --cluster reshard 192.168.14.216:7004

2、查看集群状态

3、可以删除节点

[root@node1 ~]# redis-cli -a 123456 --cluster del-node 192.168.14.216:7004 f0664536e57a84ea93c5550fe7c7328aa741dbf4

原7004的slave节点自动变为7001的slave节点

三、故障自动转移

1、手动停掉node1的master节点7001,模拟故障

[root@node1 ~]# redis-cli -c -h 192.168.14.210 -p 7001 -a 123456 shutdown

2、查看集群状态,7001已经故障。8004自动切换为master节点,8002变为8004的slave节点

四、恢复故障

1、启动7001节点

[root@node1 ~]# redis-server /usr/local/redis/cluster/redis_7001.conf

2、原master7001节点恢复之后,不会抢占master节点,而是变为slave节点。

3、再次查看之前设定的值依然存在

至此,集群在线伸缩扩展,故障转移完成。

发布了132 篇原创文章 · 获赞 118 · 访问量 25万+

猜你喜欢

转载自blog.csdn.net/tladagio/article/details/103594817