Redis中主、从库宕机如何恢复?

Redis 中主、从库宕机如何恢复?

1、什么是哨兵

哨兵是对 Redis 的系统的运行情况的监控,它是一个独立进程,功能有二个:

  • 监控主数据库和从数据库是否运行正常;

  • 主数据出现故障后自动将从数据库转化为主数据库;

2、原理

单个哨兵的架构:

Redis 中主、从库宕机如何恢复?

多个哨兵的架构:

Redis 中主、从库宕机如何恢复?

多个哨兵,不仅同时监控主从数据库,而且哨兵之间互为监控。

多个哨兵,防止哨兵单点故障。

3、环境

当前处于一主多从的环境中:

Redis 中主、从库宕机如何恢复?

4、设置哨兵

启动哨兵进程首先需要创建哨兵配置文件:

vim sentinel.conf

输入内容:

sentinel monitor taotaoMaster 127.0.0.1 6379 1

说明:

  • taotaoMaster:监控主数据的名称,自定义即可,可以使用大小写字母和“.-_”符号

  • 127.0.0.1:监控的主数据库的 IP

  • 6379:监控的主数据库的端口

  • 1:最低通过票数

启动哨兵进程:

redis-sentinel ./sentinel.conf

Redis 中主、从库宕机如何恢复?

由上图可以看到:

  • 哨兵已经启动,它的 id 为 9059917216012421e8e89a4aa02f15b75346d2b7

  • 为 master 数据库添加了一个监控

  • 发现了 2 个 slave(由此可以看出,哨兵无需配置 slave,只需要指定 master,哨兵会自动发现 slave)

5、从宕机及恢复

Redis 中主、从库宕机如何恢复?

kill 掉 2826 进程后,30 秒后哨兵的控制台输出:

2989:X 05 Jun 20:09:33.509 # +sdown slave 127.0.0.1:6380 127.0.0.1 6380 @ taotaoMaster 127.0.0.1 6379

说明已经监控到 slave 宕机了,那么,如果我们将 3380 端口的 redis 实例启动后,会自动加入到主从复制吗?

2989:X 05 Jun 20:13:22.716 * +reboot slave 127.0.0.1:6380 127.0.0.1 6380 @ taotaoMaster 127.0.0.1 6379


2989:X 05 Jun 20:13:22.788 # -sdown slave 127.0.0.1:6380 127.0.0.1 6380 @ taotaoMaster 127.0.0.1 6379

可以看出,slave 从新加入到了主从复制中。-sdown:说明是恢复服务。

Redis 中主、从库宕机如何恢复?

6、主宕机及恢复

哨兵控制台打印出如下信息:

16:50.566 * +slave-reconf-sent slave 127.0.0.1:6380 127.0.0.1 6380 @ taotaoMaster 127.0.0.1 6379

2989:X 05 Jun 20:16:51.333 * +slave-reconf-inprog slave 127.0.0.1:6380 127.0.0.1 6380 @ taotaoMaster 127.0.0.1 6379

2989:X 05 Jun 20:16:52.382 * +slave-reconf-done slave 127.0.0.1:6380 127.0.0.1 6380 @ taotaoMaster 127.0.0.1 6379

2989:X 05 Jun 20:16:52.438 # +failover-end master taotaoMaster 127.0.0.1 6379 故障恢复完成

2989:X 05 Jun 20:16:52.438 # +switch-master taotaoMaster 127.0.0.1 6379 127.0.0.1 6381  主数据库从 6379 转变为 6381

2989:X 05 Jun 20:16:52.438 * +slave slave 127.0.0.1:6380 127.0.0.1 6380 @ taotaoMaster 127.0.0.1 6381  添加 6380 为 6381 的从库

2989:X 05 Jun 20:16:52.438 * +slave slave 127.0.0.1:6379 127.0.0.1 6379 @ taotaoMaster 127.0.0.1 6381  添加 6379 为 6381 的从库

2989:X 05 Jun 20:17:22.463 # +sdown slave 127.0.0.1:6379 127.0.0.1 6379 @ taotaoMaster 127.0.0.1 6381 发现 6379 已经宕机,等待 6379 的恢复
Redis 中主、从库宕机如何恢复?

可以看出,目前,6381 位 master,拥有一个 slave 为 6380.

接下来,我们恢复 6379 查看状态:


2989:X 05 Jun 20:35:32.172 # -sdown slave 127.0.0.1:6379 127.0.0.1 6379 @ taotaoMaster 127.0.0.1 6381  6379 已经恢复服务 2989:X 05 Jun 20:35:42.137 * +convert-to-slave slave 127.0.0.1:6379 127.0.0.1 6379 @ taotaoMaster 127.0.0.1 6381  将 6379 设置为 6381 的 slave
Redis 中主、从库宕机如何恢复?

7、配置多个哨兵

vim sentinel.conf

输入内容:


sentinel monitor taotaoMaster1 127.0.0.1 6381 1

sentinel monitor taotaoMaster2 127.0.0.1 6381 2

Redis 中主、从库宕机如何恢复?

 

文章转载:  程序员老鬼
(版权归原作者所有,侵删)

© 版权声明

☆ END ☆
喜欢就点个赞吧
点赞0 分享
图片正在生成中,请稍后...