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

导读:本篇文章讲解 Redis集群管理:在线伸缩扩展、故障转移,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

实验环境

主机名        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

一、增加节点

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

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

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

3、node1查看集群状态,

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

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

4、给node4分配slot槽

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

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

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

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

6、新增一个slave节点8004

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

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

7、查看集群状态

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

二、删除节点

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

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

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

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

2、查看集群状态

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

3、可以删除节点

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

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

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

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

三、故障自动转移

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

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节点

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

四、恢复故障

1、启动7001节点

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

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

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

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

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/95248.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!