iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Redis哨兵模式是什么
  • 1061
分享到

Redis哨兵模式是什么

2024-04-02 19:04:59 1061人浏览 安东尼
摘要

这篇文章主要讲解了“Redis哨兵模式是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Redis哨兵模式是什么”吧!哨兵模式1. 哨兵概念在一主多从结构

这篇文章主要讲解了“Redis哨兵模式是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Redis哨兵模式是什么”吧!

Redis哨兵模式是什么

哨兵模式

1. 哨兵概念

  • 在一主多从结构中,如果master宕机了,就需要从多个slave中选出一个作为新的master,要想完成这样的功能,就需要使用Redis的哨兵机制

  • 哨兵 (sentinel) 是一个分布式系统,用于对主从结构中的每台服务器进行监控,当出现故障时通过投票机制选择新的master并将所有slave连接到新的master,如下图所示:

    Redis哨兵模式是什么

2. 哨兵作用

  • 监控监控master和slave

    • 不断的检查master和slave是否正常运行

    • master存活检测、master与slave运行情况检测

  • 通知(提醒):当被监控的服务器出现问题时,向其他哨兵、Redis服务器发送通知

  • 故障转移:断开宕机的master与slave的连接,选取一个slave作为master,将其他slave连接新的master,并告知客户端新的服务器地址

注意:哨兵也是一台redis服务器,仅提供监控服务,不提供数据管理服务;通常哨兵的数量配置为单数(方便投票)

3. 启用哨兵

  • 修改哨兵的配置文件 sentinel.conf ,配置文件位于Redis目录下,如下图所示:

    Redis哨兵模式是什么Redis哨兵模式是什么

  • 部分配置的含义如下图所示:

    Redis哨兵模式是什么

  • 启动哨兵

    redis-sentinel filename 
    #filename指的是配置文件名
    #每个哨兵都要配置自己的配置文件
  • 配置并启动哨兵之后,主服务器宕机之后,会自动的执行投票、主从切换等过程

4. 哨兵原理

哨兵在进行主从切换过程中经历三个阶段:

  • 监控

  • 通知

  • 故障转移

4.1 监控

用于同步各个节点的状态信息,这些节点包括master、slave、哨兵,也就是整个系统所有服务器的信息。

主要完成的功能:

Redis哨兵模式是什么

  • 获取各个sentinel的状态(是否在线):新添加的哨兵要与系统中已经存在的哨兵进行信息的交互

  • 获取master的状态(通过info指令)

    • 获取的内容如下

      1. master属性
      	 runid
      	 role:master
      2. 各个slave在master中保存的基本信息
  • 获取所有slave的状态(根据master中slave的信息向所有的slave发送info指令)

    • 获取的内容如下

      slave属性
      	runid
      	role:slave
      	master_host、master_port
      	offset

具体的内部工作原理如下所述:

Redis哨兵模式是什么

  • 哨兵1向master发送info指令之后,会建立一个cmd连接,创建的连接是用来发送命令的

  • 创建好cmd连接之后,会在哨兵1这一端保存目前他所获得的所有信息,另一端master也会保存自己持有的信息

  • 然后哨兵1根据从master获取的关于salve的信息,向slave发送info指令,得到salve的信息,丰富这一端所保存的信息

  • 当新增一个新的哨兵2时,哨兵2向master发送info指令,建立cmd连接,根据master中的信息可以得到之前已经存在的哨兵1,在自己这一端保存已经获得的信息。然后判断哨兵1是否在线,与哨兵1建立连接,二者互相交换各自的信息,并且双方会持续的ping,保证他们之间是畅通的

  • 哨兵2根据从master获得的slave信息,再从slave获取信息,丰富自己所保存的信息

  • 再新增一个哨兵3时,与之前的过程类似,最终三个哨兵建立起了关系网

  • 关系网中三者会互相交换、发送信息,关系网中的这种工作模式称为发布订阅模式

4.2 通知

哨兵在通知阶段要不断的去获取master与slave的信息,然后将获得的信息在各个哨兵之间进行共享。

具体的流程如下:

哨兵通过建立的cmd连接,向master、slave发送 hello 指令,得到他们的信息,然后在关系网中共享:

Redis哨兵模式是什么

4.3 故障转移

断开宕机的master与slave的连接,选取一个slave作为master,将其他slave连接新的master,并告知客户端新的服务器地址。

具体的流程如下所述:

  • 哨兵1始终得不到master的回应,主观判断master宕机,标记 sdown(仅有一个哨兵认为master宕机)

  • 哨兵1在关系网中传递消息,向其他哨兵发送图中左上角的消息

  • 其他哨兵得到消息之后,全部向master发送消息,确定master是否宕机,他们也会将自己得到的结果发送给关系网中的其他哨兵,确定master宕机后,将标记改为 odown(所有哨兵探测之后,超过一半的哨兵认为master宕机)

    Redis哨兵模式是什么

  • 当认定master宕机之后,此时需要选举新的master,由哪个哨兵完成这件事要通过哨兵之间的选举决定,具体过程如下所述:

    • 在选举的时候每个哨兵手里都有一票,每个哨兵都会发出一个指令,在内网里边告诉其他哨兵自己当选举人,比如说sentinel1和sentinel2发出这个选举指令,那么sentinel3接收到他们的申请之后,sentinel3就会把自己的一票投给其中一方,根据到达的先后顺序投票,获得票的那一方就会多一张选举票,按照这样的一种形式,最终会有一个选举结果,获得票数最多的哨兵会被获选

    • 在这个过程中有可能会存在失败的现象,比如第一轮没有选举成功,那就会接着进行第二轮第三轮直到完成选举

  • 当完成哨兵之间的选举之后,接下来就要由选举胜出的哨兵去slave中挑选一个,将其变成新的master,具体的流程如下所述:

    • 不在线的OUT

    • 响应慢的OUT

    • 与原master断开时间久的OUT

    • 排除结束,开始进行选择

    • 优先级高的获选

    • offset较大的获选(比较大说明同步原来master的数据最多)

    • 若还没有选出,则最后根据runid选出

    • 哨兵在服务器列表中挑选备选master的原则:先排除,后选择

  • 选出新的master之后,哨兵发送指令给服务器:

    • 向新的master发送 slaveof no one 指令

    • 向其他slave发送 slaveof 新masterIP端口 指令

  • 同时还要告诉其他的哨兵新master是谁

感谢各位的阅读,以上就是“Redis哨兵模式是什么”的内容了,经过本文的学习后,相信大家对Redis哨兵模式是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

您可能感兴趣的文档:

--结束END--

本文标题: Redis哨兵模式是什么

本文链接: https://www.lsjlt.com/news/72556.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Redis哨兵模式是什么
    这篇文章主要讲解了“Redis哨兵模式是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Redis哨兵模式是什么”吧!哨兵模式1. 哨兵概念在一主多从结构...
    99+
    2024-04-02
  • Redis的哨兵模式指的是什么
    Redis的哨兵模式(Sentinel mode)是一种用于实现高可用性(high availability)的架构设计。在Redi...
    99+
    2024-03-12
    Redis
  • Redis哨兵模式介绍
    哨兵简介 主机"宕机" 将宕机的 master 下线找一个 slave 作为 master通知所有的 slave 连接新的 master启动新的 master ...
    99+
    2024-04-02
  • redis哨兵模式怎么开启
    redis哨兵模式的开启方法:在redis目录下创建sentinel.conf文件。编辑sentinel.conf文件添加以下内容:# sentinel monitor 被监控的主机名(自定义) 被监控的主机IP 被监控的数据库端口号 投票...
    99+
    2024-04-02
  • redis哨兵模式怎么重启
    redis哨兵模式的重启步骤:1.先停slave,后停master。2.启动master,后启动slave即可。redis哨兵模式的重启步骤:先停slave,后停master,例如:进入redis-clisaveshutdownps -ef...
    99+
    2024-04-02
  • Redis中的哨兵模式有什么用
    这篇文章将为大家详细讲解有关Redis中的哨兵模式有什么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。基本介绍哨兵(sentinel)是Redis的高可用性(High ...
    99+
    2024-04-02
  • redis哨兵模式配置的步骤是什么
    配置 Redis 哨兵模式可以分为以下几个步骤: 安装 Redis:首先需要在多台服务器上安装 Redis。 配置主服务器:...
    99+
    2023-10-26
    redis
  • Redis哨兵模式是怎么工作的
    Redis哨兵模式是一种用于监控和管理Redis主从复制集群的机制。当一个Redis主节点出现故障时,哨兵节点会自动将一个从节点提升...
    99+
    2024-05-07
    Redis
  • Docker部署Redis哨兵模式
    本篇文章给大家分享的是有关Docker部署Redis哨兵模式,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。条件三台服务器(因为需要至少三个哨兵保证安全性)【可以在阿里云上租几个...
    99+
    2023-06-06
  • redis哨兵模式如何搭建
    Redis哨兵模式是一种高可用性的Redis部署架构,它通过监控Redis主节点的状态,并在主节点失效时自动将其中一个从节点升级为主...
    99+
    2023-10-24
    redis
  • SpringBoot+Redis哨兵模式的实现
    最近学习到了Redis的哨兵模式,光看视频还不行,需要自己动手实现一遍才能加深映像,特此记录。 由于没有真实的服务器可以供我操作,所以在虚拟机上启动了3个redis服务,分别占用70...
    99+
    2024-04-02
  • Redis中的主从同步和哨兵模式是什么
    本篇内容主要讲解“Redis中的主从同步和哨兵模式是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Redis中的主从同步和哨兵模式是什么”吧!主从同步主从同...
    99+
    2024-04-02
  • Redis哨兵原理是什么
    Redis哨兵原理是什么?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!本文实现环境centos7.3 redis4.0re...
    99+
    2024-04-02
  • 怎么理解Redis中的哨兵模式
    本篇内容介绍了“怎么理解Redis中的哨兵模式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Redis 主...
    99+
    2024-04-02
  • Redis的哨兵模式和集群模式有什么区别
    Redis的哨兵模式和集群模式是两种不同的高可用架构设计: 哨兵模式(Sentinel): 哨兵模式是通过多个哨兵节点来监控主...
    99+
    2024-03-14
    Redis
  • PHP中redis哨兵模式怎么使用
    在PHP中使用Redis的哨兵模式,需要安装redis扩展,并设置哨兵模式相关的配置。 步骤如下: 安装Redis扩展:使用`p...
    99+
    2023-10-25
    PHP redis
  • Redis哨兵模式怎么配置和使用
    Redis哨兵模式是一种用于监控和管理Redis主从复制和高可用性的机制。当主服务器出现故障时,哨兵可以自动将从服务器升级为主服务器...
    99+
    2024-05-07
    Redis
  • 怎么解析Redis中的哨兵模式原理
    今天就跟大家聊聊有关怎么解析Redis中的哨兵模式原理,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 本篇文章带大家深入...
    99+
    2024-04-02
  • Redis中哨兵的原理是什么
    Redis中哨兵的原理是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。哨兵在一个典型的一主多从的Redis系统中,当主数据...
    99+
    2024-04-02
  • Redis中哨兵模式的示例分析
    小编给大家分享一下Redis中哨兵模式的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!主从切换技术的方法是:当主服务器宕...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作