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、再次查看之前设定的值依然存在

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

友人a笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值