1 Redis Sentinal机制

sentinal,中文名哨兵

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

集群监控

监控Redis master和slave进程的正常工作

消息通知

如果某个Redis实例有故障,那么哨兵负责发送报警消息给管理员

故障转移

若master node宕机,会自动转移到slave node上

配置中心

若发生故障转移,通知client客户端新的master地址

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

故障转移时,判断一个master node是否宕机,需要大部分的哨兵都同意,涉及到了分布式选举问题

即使部分哨兵节点宕机,哨兵集群还是能正常工作的

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

2 哨兵的核心知识

哨兵需要至少3个实例,保证自己的健壮性

哨兵 + Redis主从的部署架构,是不会保证数据零丢失的,只能保证redis集群的高可用性

对于哨兵 + 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 redis 哨兵_突破Java面试(23-7) - Redis的哨兵架构相关推荐

  1. java 通过redis实现倒计时_突破Java面试(42) - Redis amp; ZooKeeper两种分布式锁实现的优劣...

    0 Github 1 面试题 一般实现分布式锁都有哪些方式?使用redis如何设计分布式锁?使用zk来设计分布式锁可以吗?这两种分布式锁的实现方式哪种效率比较高? 2 考点分析 一般先问问你zk,然后 ...

  2. jedispool redis哨兵_通过java哨兵JedisSentinelPool代码示例连接对配置的redis哨兵主从模式进行测试验证...

    一.前言 本文章通过关于java的jedis(2.6.0)的redis客户端连接驱动包,对配置的redis哨兵+主从读写模式配置进行示例代码验证,详细参见具体配置步骤&示例代码说明部分. 二. ...

  3. 纯java分布式内存数据库_最新Java岗面试清单:分布式+Dubbo+线程+Redis+数据库+JVM+并发...

    最近可能有点闲的慌,没事就去找面试面经,整理了一波面试题.我大概是分成了Java基础.中级.高级,分布式,Spring架构,多线程,网络,MySQL,Redis缓存,JVM相关,调优,设计模式,算法与 ...

  4. java异常 说服力_异常常见面试题目

    1) Java中什么是Exception? 这个问题经常在第一次问有关异常的时候或者是面试菜鸟的时候问.我从来没见过面高级或者资深工程师的 时候有人问这玩意,但是对于菜鸟,是很愿意问这个的.简单来说, ...

  5. redis哨兵主从不切换_《「面试突击」—Redis篇》-- Redis的主从复制?哨兵机制?...

    Redis如何保证高并发,高可用? 高并发:redis的单机吞吐量可以达到几万不是问题,如果想提高redis的读写能力,可以用redis的主从架构,redis天热支持一主多从的准备模式,单主负责写请求 ...

  6. 网易java面经_网易Java工程师面经,面试题整理(二面)

    下面要给大家带来了的是一个小伙伴的网易Java工程师二面面经,具体内容包括了二面的面试题以及面试者的回答和面试感受. 整个面试的时常大概是34分钟左右,下面是具体的面试题和面试者的回答. 面试题(二面 ...

  7. java武功秘籍_请问java全套内容都有什么呢?

    我整理的Java全套内容学习路线,分为6个阶段(大阶段)第一阶段:java内功心法篇 第二阶段:Java武功秘籍(经典框架) 第三阶段:Java高级功法(主流框架) 第四阶段:Java成神之路 第五阶 ...

  8. java array缓存_有java数组

    [JAVA零基础入门系列]Day10 Java中的数组 [JAVA零基础入门系列](已完结)导航目录 Day1 开发环境搭建 Day2 Java集成开发环境IDEA Day3 Java基本数据类型 D ...

  9. java初始化数据报_初始化java原因

    虚拟机的类加载机制 虚拟机把描述类的数据从Class文件加载到内存,并对数据进行校验.转换解析和初始化,最终形成可以被虚拟机直接使用的Java类 即虚拟机的类加载机制. 在Java中,类型的加载.链接 ...

  10. java 数据结构实例_数据结构(Java)——栈的实例

    惟大英雄能本色,是真名士自风流 --易中天(百家讲坛) 1.表达式的转换 1.1 中缀表达式转前缀表达式 中缀表达式转前缀表达式有许多的方式,有加括号去除法.语法树遍历法.堆栈处理法1. 测试程序的实 ...

最新文章

  1. 十分钟用Windows服务器简单搭建DHCP中继代理!!
  2. 初步学习“C#枚举”
  3. 用YACC/LEX 设计计算机语言
  4. 12、Java Swing计算器界面的实现
  5. boost::hana::is_valid用法的测试程序
  6. LiveVideoStackCon深圳-服务端的任务越来越重
  7. springcloud 子项目怎么导入_「 从0到1学习微服务SpringCloud 」09 补充篇-maven父子模块项目...
  8. Retrofit2/OkHttp 重写覆盖headers 与 不重写覆盖Headers
  9. docker rabbitmq_一文看懂Rabbitmq,从安装到实战演练
  10. html按键变色,按键变色.html
  11. 团体程序设计天梯赛-练习集L1-023. 输出GPLT
  12. POJ--3984--迷宫问题
  13. 在CRM中怎么应用大数据挖掘
  14. php手机号最新正则表达式,最新手机号码正则表达式
  15. adb工具+使用adb安装apk
  16. 【面试题】计算机网络 -- 常见面试题总结
  17. 【抓包】【Mac Charles】局域网无法抓包 手机热点来解决
  18. 爬去东方财富网龙虎榜(wechat:15353378609)
  19. Xamarin for android学习总结一
  20. xmanager调出图形安装oracle,Xmanager快速连接Linux图形界面教程

热门文章

  1. linux命令(日常更新)
  2. 迅为IMX6Q PLUS开发板烧写Android6.0系统方法
  3. 8-5如何使用线程池
  4. 浅谈CDN技术的性能与优势
  5. Chapter 5. MPEG-4 Visual
  6. 学习日志-virtual,override,new,overload
  7. 搭建html5的,HTML5 - 搭建移动Web应用
  8. Security+ 学习笔记57 安全意识和培训
  9. ELK详解(二十二)——Elastalert报警配置实战
  10. 巧用 TypeScript(四)