美文网首页程序员突破Java面试Java
突破Java面试(23-7) - Redis的哨兵架构

突破Java面试(23-7) - Redis的哨兵架构

作者: JavaEdge | 来源:发表于2019-07-06 11:53 被阅读11次

Github

1 Redis Sentinal机制

sentinal,中文名哨兵

哨兵是redis集群架构中非常重要的一个组件,主要功能如下

  • 集群监控
    监控Redis master和slave进程的正常工作
  • 消息通知
    如果某个Redis实例有故障,那么哨兵负责发送报警消息给管理员
  • 故障转移
    若master node宕机,会自动转移到slave node上
  • 配置中心
    若发生故障转移,通知client客户端新的master地址

哨兵本身也是分布式的,作为一个哨兵集群去运行,协同工作

  • 故障转移时,判断一个master node是否宕机,需要大部分的哨兵都同意,涉及到了分布式选举问题
  • 即使部分哨兵节点宕机,哨兵集群还是能正常工作的

目前采用的是sentinal 2版本,sentinal 2相对于sentinal 1来说,重写了很多代码,主要是让故障转移的机制和算法变得更加健壮和简单

2 哨兵的核心知识

  1. 哨兵需要至少3个实例,保证自己的健壮性
  2. 哨兵 + Redis主从的部署架构,是不会保证数据零丢失的,只能保证redis集群的高可用性
  3. 对于哨兵 + Redis主从这种复杂的部署架构,尽量在测试环境和生产环境,都进行充足的测试和演练

3 为什么仅2个节点时无法正常工作

必须部署2个以上的节点

若仅部署2个实例,quorum=1

+----+         +----+
| M1 |---------| R1 |
| S1 |         | S2 |
+----+         +----+

Configuration: quorum = 1

master宕机,s1和s2中只要有1个哨兵认为master宕机就可以进行切换,同时会在s1和s2中选举出一个执行故障转移.

但此时,需要majority,也就是大多数哨兵都是运行的,2个哨兵的majority就是2

2个哨兵的majority=2
3个哨兵的majority=2
4个哨兵的majority=2
5个哨兵的majority=3

2个哨兵都运行着,就可以允许执行故障转移

若整个M1和S1运行的机器宕机了,那么哨兵仅剩1个,此时就无majority来允许执行故障转移,虽然另外一台机器还有一个R1,但故障转移不会执行

4 3-节点哨兵集群(经典)

       +----+
       | M1 |
       | S1 |
       +----+
          |
+----+    |    +----+
| R2 |----+----| R3 |
| S2 |         | S3 |
+----+         +----+

Configuration: quorum = 2,majority

若M1节点宕机了,还剩下2个哨兵,S2和S3可以一致认为master宕机了,然后选举出一个来执行故障转移

同时3个哨兵的majority是2,所以余存的2个哨兵运行着,就可执行故障转移

参考

《Java工程师面试突击第1季-中华石杉老师》

相关文章

  • 突破Java面试(23-7) - Redis的哨兵架构

    Github 1 Redis Sentinal机制 sentinal,中文名哨兵 哨兵是redis集群架构中非常重...

  • .netcore高级工程师面试之Redis的哨兵架构

    简介:Github 1 Redis Sentinal机制 sentinal,中文名哨兵 哨兵是redis集群架构中...

  • Redis内容整理(2021-06-29)

    Redis内容整理 目录 基础数据结构 持久化 主从架构 哨兵模式 集群配置 面试整理[https://www.j...

  • 5.Redis的哨兵服务

    0.Redis主从架构的问题1.哨兵服务介绍2.架构图3.主从服务搭建4.配置哨兵服务5.启动哨兵服务6.验证哨兵...

  • Redis哨兵架构

    Sentinel是Redis的高可用性解决方案:由一个或多个Sentinel实例组成的系统可以监视任意多个主服务器...

  • Redis哨兵机制简介

    Redis提供两种高可用解决方案,哨兵和集群,本文主要介绍哨兵系统的架构、高可用原理和故障处理过程。 Redis哨...

  • 面试题一

    Redis 如何保证防止穿透 和雪崩Redis 如何模糊查询数据Redis 哨兵和cluster 架构有何区别S...

  • 15. Redis 哨兵

    10. Redis哨兵(高可用) 10.1 redis集群介绍 主从架构无法实现master和slave角色的自动...

  • 缓存架构之11:redis哨兵架构的相关基础知识的讲解

    1、哨兵的介绍 sentinal,中文名是哨兵 哨兵是redis集群架构中非常重要的一个组件,主要功能如下 (1)...

  • redis哨兵基础

    1、哨兵的介绍 sentinal,中文名是哨兵 哨兵是redis集群架构中非常重要的一个组件,主要功能如下 (1)...

网友评论

    本文标题:突破Java面试(23-7) - Redis的哨兵架构

    本文链接:https://www.haomeiwen.com/subject/xjkphctx.html