Redis哨兵模式

news2024/9/21 2:45:10
  • 什么是哨兵模式

        哨兵模式是Redis高可用的解决方案,使用Sentinel(哨兵)监控Redis集群中全部节点的运行状态,当主节点服务宕机后,会从当前主节点下的从节点中选一个节点作为新的主节点,继续为用户提供服务。当原主节点重新启动后,不会重新作为主节点运行,只能作为从节点运行。

  • 哨兵模式的优点

        相对于主从模式,哨兵模式更加高可用,因为主从模式中,当主节点宕机后,就无法继续提供服务了,需要手动启动,但是哨兵模式可以选出新的主节点,继续提供服务。

  • 哨兵模式示意图

        哨兵模式可以使用单独的哨兵也可以使用多个哨兵,单哨兵模式如图:

        使用一个哨兵,检测多个Redis节点的运行状态。当主节点宕机后,哨兵选出新的主节点即可。但是这种模式有缺点,就是哨兵服务自己宕机,那么就没有办法检测Redis节点了,所以可以引入多个哨兵,如图:

        在多哨兵模式下,每个哨兵除了检测所有节点的运行状态外,还要检测其他哨兵的运行状态。

  • 哨兵检测方式

        哨兵通过心跳机制,实现对节点和其他哨兵的状态检测,每秒钟向集群中所有节点发送ping命令。

  • 判定节点下线方法

        当有一个哨兵发现某个节点没有在规定时间内做出相应,则认为该节点下线,被称为主观下线。

        当其他哨兵也检测到该节点下线,并且达到了一定数量(具体由哨兵的监控配置决定,比如超过一半),那么就标记该节点为客观下线。

        如果该节点是主节点,那么就要发起投票,选出新的主节点。

  • 选举新的主节点

        哨兵选举主节点是一个很严谨的过程,主要是由一下因素决定。

        1、节点与主节点连接时长

        如果从节点与主节点断开的时长超过down-after-milliseconds的十倍外加主节点宕机时长,那么就认为该节点不适合做主节点。

        2、优先级

        通过 slave-priority 配置项(redis.conf),可以给不同的从库设置不同优先级,优先级高的优先成为master。

        3、复制偏移量

        选择数据偏移量差距最小的,即slave_repl_offset与 master_repl_offset进度差距,差距越小数据与主节点差的越少。

        4、运行ID(run id)

        运行ID越小,说明运行时间越早,所以选run id小的从节点。

  • 消息通知

        更新主节点后,通知其他从节点,所有从节点重新slave of到新的主节点上,重新建立runID和slave_repl_offset,此后写数据时都写入到新的主节点上。

  • 哨兵集群通信方式

        使用redis的pub/sub 订阅能力实现哨兵间通信 和 slave 发现。

        哨兵之间可以相互通信,主要归功于 Redis 的 pub/sub 发布/订阅机制。哨兵与 master 建立通信之后,可以利用 master 提供发布/订阅机制发布自己的IP、port等信息,master 有一个 sentinel:hello 的专用通道,用于哨兵之间发布和订阅消息。哨兵们都可以通过该通道发布自己的Name、IP、Port消息,同时订阅其他哨兵发布的Name、IP、Port消息。互相发现之后建立起了连接,后续的消息通信就可以直接进行了。

  • 哨兵集群通信方式

        sentinel向master发送 INFO 命令,master返回与之关联的slave 列表,sentinel 根据 master 返回的 slave 列表,逐个与 salve 建立连接,并且根据这个连接持续监控。

  • 哨兵与客户端进行事件通知

        依旧是通过 pub/sub 机制,发布不同事件,让客户端在这里订阅消息。客户端可以订阅哨兵的消息,哨兵提供的消息订阅频道有很多,不同频道包含了主从库切换过程中的不同关键事件。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/13181.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

个人博客类网站为什么更适合虚拟主机?

对于各位站长来说,建立网站有多种主机选项可以选择,比如,虚拟主机、云主机,物理机等。那么为什么说个人博客类网站更适合选用虚拟主机而不是其他类型的主机呢? 个人博客类网站更适合虚拟主机的理由: 首先,…

基于STM32结合CubeMX学习Free-RT-OS的源码之两类中断解析

目录 认识 常见的中断应用场景 进入与退出临界区(开中断与关中断) Free RTOS的systick中断 和 PendSV中断。 Cortex-M3/4的工作模式以及双堆栈指针MSP和PSP(CPU与OS的相辅相成与互相成就) 为什么要引入这两种工作状态? 为什么…

Debian Linux 的安装

Debian Linux 的安装 作者:Grey 原文地址: 博客园:Debian Linux 的安装 CSDN:Debian Linux 的安装 说明 本安装说明是基于 Windows 10 下 VMware workstation 16 安装 Linux,Linux 版本是 Debian 11,需…

K8s集群环境搭建

K8s集群环境搭建 修改hosts文件 [rootmaster ~]# vim /etc/hosts [rootmaster ~]# cat /etc/hosts 127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4 ::1 localhost localhost.localdomain localhost6 localhost6.localdomain6 192.…

TCO点击试剂(4E)-TCO-PEG4-amine, 2243569-24-4,反式环辛烯-四聚乙二醇-氨基

【产品描述】 (4E)-反式环辛烯-四聚乙二醇-氨基,胺与活性NHS酯或在活化剂suh(如EDC)存在下与羧酸非常反应,TCO部分使四嗪分子实现快速点击化学。亲水性PEG间隔臂提高了水溶性,并提供了一个长而灵活的连接。西安凯新生物…

软件测试的几种模型

1.V模型 在软件测试方面,V模型是最广为人知的模型。如图,V模型从左到右描述了开发过程和测试行为。V模型的价值在于它非常明确的表明了测试过程中存在的不同级别,并且清楚的描述了这些测试阶段和开发过程各阶段的对应关系。缺点:把…

Selenium基础 — POM设计模式(一)

(一)POM模式介绍 1、什么是POM? POM是Page Object Model页面对象模型的简称。 POM是为Web UI元素创建Object Repository的设计模式 。 在这个模型下,对于应用程序中的每个网页,应该有相应的页面类。 此Page类将会找到…

ES新特性与TypeScript、JS性能优化

一、ECMAScript 新特性 1、作用域 1、全局作用域 2、函数作用域 3、块级作用域2、var、let和const的区别 1、let和var用来声明变量,const用来声明常量(变量就是赋值后可以改变它的值,常量就是赋值后就不能改变它的值) 2、const…

Unity 资源热更新

热更新流程 启动游戏根据当前版本号,和平台号去版本服务器上检查是否有热更从热更服务器上下载md5文件,比对需要热更的具体文件列表从热更服务器上下载需要热更的资源,解压到热更资源目录游戏运行加载资源,优先到热更目录中加载&…

windows下载redis、windows安装redis、windows启动redis

一、下载并解压 下载网址:https://github.com/tporadowski/redis/releases 下载后解压并重命名文件夹为redis 二、打开redis文件夹 找到redis.windows.conf配置文件,作如下修改 protected-mode no // 将yes改为no 部分配置信息说明 bind 127.0.…

Ubuntu服务器下安装FastDFS及nginx配置访问等问题记录

Ubuntu服务器下安装FastDFS及nginx配置访问下载对应包编译环境包解压环境配置配置nginx模块和安装nginx来进行访问该图片下载对应包 下载方式一:直接使用 wget 下载,如果太慢,可以去github下载,然后上传到服务器上即可。 wget -…

Mybatis三大执行器介绍

Mybatis三大执行器介绍Mybatis相关全览一、执行器介绍执行器的选择入口设置执行器两种方式全局配置(不建议)局部设置(建议)二、三个执行器区别SimpleExecutorReuseExecutorBatchExecutor总结三、效率测试四、平时开发使用本文用的…

老机器摇身一变成局域网下低配服务器,并稳定访问GitHub

老机器摇身一变成局域网下低配服务器,并稳定访问GitHub 搭建场景: 问题背景: 最近用腾讯云服务器访问GitHub经常挂,试了很多解决方案如换host文件ip等办法提速效果都不明显。后来想通过腾讯云服务器实现kexueshangwang&#xff0…

wechaty-puppet-whatsapp的uos协议使用中常见问题

常见问题 常见问题解决基本方案 先检查node版本是否大于16确认npm已经配置好淘宝源存在package-lock.json文件先删除删除node_modules后重新执行npm install 或cnpm install配置文件是否按照要求设置本地网络是否存在限制,是否开启了代理服务本地防火墙是否关闭 我…

智能微型断路器的功能有哪些?和网关搭配的作用在哪?

安科瑞 华楠 ASCB1 系列智能微型断路器是安科瑞电气股份有限公司 全新推出的智慧用电产品,产品由智能微型断路器与智 能网关两部分组成,可用于对用电线路的关键电气因 素,如电压、电流、功率、温度、漏电、能耗等进行实 时监测,具…

[附源码]java毕业设计剧本杀门店管理系统-

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

三种常规用的矢量网络分析仪系统误差校准方法

我们在使用矢量网络分析仪是会发现测量出来的数据有误差,要想矫正,首先我我们要知道矢量网络分析仪的误差来源有哪些?主要有以下三个方面:漂移误差、随机误差、系统误差 1、漂移误差:是由于进行校准之后仪器或测试系统性能发生变…

网络基础--笔记

文章目录一、网络基础1.1 二层交换网络1.1.1 HUB1.1.2 Switch1.1. 3 ARP协议1.1. 4 VLAN IEEE802.1Q协议1.1. 5 链路接口类型1.1. 6 链路聚合模式1.1. 7 链路聚合的类型1.1. 8 STP 生成树协议 (Spanning Tree protocol) IEEE 802.1D1.2 三层路由网络1.2.…

HDLC协议的特点及功能,让你一看就会

一 HDLC概述 1.1 HDLC的发展历史 高级数据链路控制(High-Level Data Link Control或简称HDLC),是一个在同步网上传输数据、面向比特的数据链路层协议,它是由国际标准化组织(ISO)根据IBM公司的SDLC(SynchronousData Link Control)协议扩展开发而成的.其最…

[附源码]Python计算机毕业设计《数据库系统原理》在线学习平台

项目运行 环境配置: Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术: django python Vue 等等组成,B/S模式 pychram管理等等。 环境需要 1.运行环境:最好是python3.7.7,…