redis 笔记2之哨兵


一、哨兵

1.1 简介

上篇说了复制,有个缺点就是主机宕机之后,从机只会原地待命,并不能升级为主机,这就不能保证对外服务了,所以出现了哨兵,来监控主机和从机的状态。
在这里插入图片描述

1.2 实操

前提说明:
在这里插入图片描述

1.2.1 sentinel.conf

参数:
在这里插入图片描述
重点:在这里插入图片描述
其他:
在这里插入图片描述

客观下线
在这里插入图片描述在这里插入图片描述
其中一台哨兵的重要配置参数编写在这里插入图片描述

哨兵会监控主机和其他从机以及其他主机,我们只配置了主机ip和端口,但是会通过内容传递获得主机下的从机以及监控此主机的其他哨兵。在这里插入图片描述

添加了哨兵之后,主机上的redis.conf也要配置密码masterauth,防止主机宕机,变成从机之后,也需要去拜新的主机。
在这里插入图片描述

1.2.2 问题

在这里插入图片描述
主机宕机,哨兵会从从机中投票选举出新的主机,并且两台从机的数据依然存在。
如果之前宕机的主机重启回来,被选举出来的master不会变,而老的master会变成slave。

由于我们切换了主机,所以对应的文件内容也要进行更改。
在这里插入图片描述
比如哨兵,它监控的主机名ip端口就会发生变化。
在这里插入图片描述
原来的主机重启之后 由于变成了从机 所以需要隶属关系,哨兵自动帮我们加入。
在这里插入图片描述

而重新变成master的从机,由于不在依附别的机器,所以原来的replicaof 自动被消除了。
在这里插入图片描述

1.2.3 哨兵执行流程和选举原理

在这里插入图片描述
主观下线:
哨兵的配置文件中有默认时间,如果在规定时间内,主机没有回应,当前哨兵就会判断该主机宕机了。
客观下线:
但是,一个哨兵判断主机宕机并不可靠,因为可能网络会有延迟,所以需要所有哨兵来投票,就是我们上述配置文件中的参数,当超过该参数为就确定该主机确实宕机了。
选举出领导者哨兵
哨兵有多个,如果每个哨兵都有话语权去选举新的主机,就会造成混乱,所以需要先找出一个兵王。由该兵王来进行选举和后续故障迁移操作(比如给新的主机发送信息,以及给其他从机发送需要依附于新的主机命令)。
在这里插入图片描述
在这里插入图片描述

兵王选举出一个新的master并进行后续故障迁移
在这里插入图片描述

选举规则
在这里插入图片描述

在这里插入图片描述
先看配置文件中的参数,数值越小,优先级越高,然后看谁复制原来主机的数据多,最后看谁的id小。
在这里插入图片描述
在这里插入图片描述

1.2.4 使用建议

哨兵+主从复制并不能达到数据零丢失。
在这里插入图片描述

相关推荐

  1. Redis部署哨兵

    2024-06-15 16:30:03       16 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-15 16:30:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-15 16:30:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-15 16:30:03       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-15 16:30:03       20 阅读

热门阅读

  1. win10下使用docker和VMware

    2024-06-15 16:30:03       8 阅读
  2. Android 14 蓝牙主从模式切换

    2024-06-15 16:30:03       10 阅读
  3. C# —— 位运算符

    2024-06-15 16:30:03       5 阅读
  4. vim 存在三种模式:

    2024-06-15 16:30:03       5 阅读
  5. k8s_探针专题

    2024-06-15 16:30:03       8 阅读
  6. 行为型-观察者模式(Observer)

    2024-06-15 16:30:03       9 阅读
  7. 递归下降解析器在Python中的实现与应用

    2024-06-15 16:30:03       7 阅读
  8. 虚谷数据库-定时作业

    2024-06-15 16:30:03       7 阅读
  9. flutter实现UDP发送魔法包唤醒主机

    2024-06-15 16:30:03       4 阅读
  10. 前端根据权限生成三级路由

    2024-06-15 16:30:03       7 阅读