Redis 的主从复制模式下,一旦主节点由于故障不能提供服务,需要人工进

行主从切换,同时大量的客户端需要被通知切换到新的主节点上,对于上了一定规模的应用来说,这种方案是无法接受的,于是Redis从2.8开始提供了RedisSentinel(哨兵)来解决这个问题。

哨兵模式的作用

哨兵也叫 sentinel,它的作用是能够在后台监控主机是否故障,如果故障了根据投票数自动将从库转换为主库。

如果master宕机了,sential会从剩下的从服务器节点中选择一台提升为master,然后自动修改相关配置,选举策略如下:

  1. 选择优先级靠前的服务器。优先级的配置在 redis.conf 文件中的 replica-priority 配置,默认为 100,值越小优先级越高。

  2. 选择偏移量最大的。偏移量是指获得原主机数据最全的。

  3. 选择 runid 最小的从服务器。每个redis实例启动后都会随机生成一个40位的runid。

Redis Sentinel中的Sentinel节点个数应该为大于等于3且最好为奇数

哨兵集群为什么建议部署 “奇数个节点”?比如 3 个、5 个,而不是 2 个、4 个?

核心原因:避免 “投票脑裂”,确保故障转移时能选出 “领头哨兵” 和新主库。

哨兵的关键投票场景需要 “超过半数节点同意”:

配置哨兵模式

  • 首先配置好三台主机的/etc/reids/redis.cnf文件

vim /etc/redis/redis.conf
bind 0.0.0.0
protected-mode no
daemonize no  

  • 重新启动redis服务
systemctl start redis
  • 配置好redis的主从同步
  • 查看master主从情况---------- 两个从都是在线的状态下


  • 接着配置三台主机的哨兵配置文件
port 26379  #监听端口
daemonize no  #后台运行
pidfile /var/run/redis-sentinel.pid
logfile /var/log/redis/sentinel.log
sentinel monitor mymaster 192.168.1.20 6379 2  
#monitor:监控
#mymaster为监控对象起的服务名称
#2表示只有2个或2个以上的哨兵认为主节点不可用的时候,才会把 master 设置为客观下线状态,然后进行 failover 操作。
sentinel down-after-milliseconds mymaster 30000   #master中断时长, 30秒连不上视为master下线
sentinel parallel-syncs mymaster 1  #发生故障转移后,同时开始同步新master数据的slave数量
sentinel failover-timeout mymaster 180000 #整个故障切换的超时时间为3分钟
  • 现在master上配置好哨兵配置文件---再将配置好的哨兵文件传到slave1.slave2上对他们原来的哨兵文件进行覆盖
scp /etc/redis/sentinel.conf root@192.168.1.21:/etc/redis
scp /etc/redis/sentinel.conf root@192.168.1.22:/etc/redis 

重新启动哨兵服务

systemctl restart redis-sentinel.service

测试---模拟master故障

  • 首先将master的redis服务关闭
shutdown

  • 然后查看slave1的状态----查看master是否成功转移slave1上

  • 查看slave2的主从状态

master成功转移到slave1上并,salve2的主库也成功变成slave1

  • 查看slave2的redis配置文件--查看哨兵是否检测到故障并且更改slave2文件的主

哨兵自动更改了master的IP为slave1的ip

注意

/etc/redis/sentinel.conf 文件在用哨兵程序调用后会被更改,如果需要重新做要删掉文件重新编辑。

  1. 由于所有的写操作都是先在Master上操作,然后同步更新到Slave上,所以从Master同步到Slave机器有定的延迟,当系统很繁忙的时候,延迟问题会更加严重,Slave机器数量的增加也会使这个问题更加严重。
  2. 在生产环境中如果master和slave中的网络出现故障,由于哨兵的存在会把master提出去当网络恢复谷master发现环境发生改变,master就会把自己的身份转换成slave。master变成slave后会把网络故障那段时间写入自己中的数据清掉,这样数据就丢失了。
  3. 解决办法:master在被写入数据时会持续连接slave, mater确保有2slave可以写入我才允许写入,如果slave数量少于2个便拒绝写入

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

安徽某能源企业积极推进运维智能化转型,引入高压配电房机器人巡检系统

在工业自动化与智能化深度融合的当下,机器人技术已成为能源行业提质增效的关键支撑。特别是在配电房这类高压电力核心区域的运维工作中,传统人工巡检不仅面临效率低下、巡检周期长的困境,更因人员直接接触高压设备而存在极高的安全风险。此&a…

数据结构_二叉平衡树

#include <stdio.h> #include <stdlib.h> #define max(a,b) ((a > b)? (a):(b))//平衡二叉树的节点结构 typedef struct AVL_TreeNode{int data; //数据域struct AVL_TreeNode* l;struct AVL_TreeNode* r;int h;//记录树的高度&#xff0c;用于计算平衡因子 }…

扫描件、PDF、图片都能比对!让文档差异无所遁形

智能文档比对系统可精准识别文档差异&#xff0c;解决金融、法律等多方协作场景下的版本混乱、审核低效和合规风险问题&#xff0c;将一份百页文档的人工核对从数小时缩短至3分钟以内。 文档差异比对常见场景有哪些&#xff1f; 每一次文档的修改都可能带来潜在风险&#xff0c…

excel里面店铺这一列的数据结构是2C【uniteasone17】这种,我想只保留前面的2C部分,后面的【uniteasone17】不要

这个结构是&#xff1a; 2C【uniteasone17】只要取前面的 2C 部分&#xff0c;可以用 Excel 的 公式 或者 文本函数 来实现。 方法 1&#xff1a;使用公式提取 假设店铺数据在 A2 单元格&#xff1a; LEFT(A2,FIND("【",A2)-1)&#x1f449; 解释&#xff1a; FIND(“…

四、神经网络的学习(中)

4.3 数值微分梯度法使用梯度的信息决定前进的方向。本节将介绍梯度是什么、有什么性质等内容。4.3.1 导数假如你是全程马拉松选手&#xff0c;在开始的10分钟内跑了2千米。如果要计算此时的奔跑速度&#xff0c;则为2/10 0.2&#xff3b;千米/分&#xff3d;。也就是说&#x…

Jenkins 监控方案:Prometheus + Grafana 实践

这两天在运维群里面看到有人说 Jenkins 节点也可以监控&#xff0c;以前没想过搞这个&#xff0c;现在就对公司 Jenkins 搞搞顺便记录下呗。 一、使用 Jenkins Prometheus 插件&#xff08;推荐方式&#xff09; 1. 安装插件 在 Jenkins 插件管理里搜索并安装 Prometheus Me…

用博图FB类比c#中sdk的api

我有一个大胆的想法我准备自己做个简单的视觉软件来锻炼自己的c#编程能力&#xff0c;我准备用到海康工业机器人官网下载的mvs软件的sdk,听说sdk的主要作用就是api提供了开放的接口给第三方免费调用。按照我的理解&#xff0c;api接口就像西门子博图的FB块&#xff0c;所谓api接…

【Leetcode】高频SQL基础题--1164.指定日期的产品价格

【Leetcode】高频SQL基础题–1164.指定日期的产品价格 要求&#xff1a;一开始&#xff0c;所有产品价格都为 10。编写一个解决方案&#xff0c;找出在 2019-08-16 所有产品的价格。 以 任意顺序 返回结果表。解题思路&#xff1a; 找到 2019-08-16 前所有有改动的产品及其最新…

Django全局异常处理全攻略

在 Django 中处理全局异常&#xff0c;有几种常见的方式&#xff0c;通常目标是&#xff1a; 捕获项目中未被单独处理的错误统一返回给前端&#xff08;如 JSON 响应 / 自定义错误页&#xff09;方便记录日志1. 使用 Django 自带的全局异常处理机制 Django 有一些内置的全局错误…

【开题答辩全过程】以电商数据可视化系统为例,包含答辩的问题和答案

个人简介一名14年经验的资深毕设内行人&#xff0c;语言擅长Java、php、微信小程序、Python、Golang、安卓Android等开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。感谢大家的…

MyBatis入门到精通:CRUD实战指南

1. MyBatisORM&#xff1a;对象关系映射O&#xff08;Object&#xff09;&#xff1a;Java虚拟机中的Java对象R&#xff08;Relational&#xff09;&#xff1a;关系型数据库M&#xff08;Mapping&#xff09;&#xff1a;将Java虚拟机中的Java对象映射到数据库表中一行记录&am…

WebRTC开启实时通信新时代

摘要&#xff1a;WebRTC&#xff08;Web实时通信&#xff09;是一项开源技术&#xff0c;支持浏览器直接进行低延迟音视频通信和数据传输&#xff0c;无需安装插件。其核心技术包括RTCPeerConnection&#xff08;建立点对点连接&#xff09;、MediaStream&#xff08;媒体流处理…

【51单片机8*8点阵显示箭头动画详细注释】2022-12-1

缘由51单片机实现8*8滚动箭头的程序,运行时什么图案都没有,甚至根本不亮 - 24小时必答区 #include<reg52.h> unsigned char code M[]{0xff,0xff,0xfe,0xfd,0xf8,0xfd,0xfe,0xff,0xff,0xff,0xfd,0xfb,0xf0,0xfb,0xfd,0xff,0xff,0xff,0xfb,0xf7,0xe0,0xf7,0xfb,0xff,0xff,0…

手撕Redis底层3-持久化机制与集群化方案

1.Redis持久化机制Redis设计了两种持久化落盘机制&#xff1a;RDB和AOF1.1 RDB持久化RDB持久化是Redis的数据快照&#xff0c;简单来说就是把内存中的所有数据都记录到磁盘中&#xff0c;当Redis实例故障重启后&#xff0c;从磁盘中读取快照文件来恢复数据。快照文件称为RDB文件…

mysql中null值对in子查询的影响

1、场景 有这样一个查询&#xff0c;有些时候是正确的&#xff0c;有些时候没报错但是又查询不到数据&#xff0c;分析数据排查后发现当user_id字段存在null值的时候查询不到数据。select * from table1 where id in (select user_id from talbe2 where status1);2、问题 为什么…

如何在 tortoise-orm 内使用 JSON_EXTRACT

先说结论&#xff1a; # 假设 JsonField 名称为 data&#xff0c;内容为 {"info": {"path": "我的资源创建"}} qs qs.filter(data__filter{"info.path": "我的资源创建"})我查看了 tortoise-orm 官方文档&#xff0c;没有这…

西门子S7-200 SMART PLC:编写最基础的“起保停”程序

一、什么是“起保停”电路&#xff1f;“起保停”是“启动-保持-停止”的简称&#xff0c;也称为“自锁电路”。它是继电器控制系统和PLC程序中最基本、最核心的控制逻辑。启动 (Start): 由一个点动按钮&#xff08;常开触点&#xff09;触发&#xff0c;使设备运行。保持 (H…

漏洞修复 Nginx SSL/TLS 弱密码套件

扫描结果 [rootlocalhost nmap]# docker run --rm -v $(pwd)/results:/results securecodebox/nmap nmap --script ssl-enum-ciphers -p 443 xxx.cn -oX /results/output_0904.xml Starting Nmap 7.80 ( https://nmap.org ) at 2025-09-04 05:02 UTC Nmap scan report for xxx.…

ChartGPT深度体验:AI图表生成工具如何高效实现数据可视化与图表美化?

最近帮运营同事做季度数据报告时&#xff0c;我差点在图表样式上栽跟头 —— 明明数据都算好了&#xff0c;用 Excel 调柱状图的颜色、字体、坐标轴标签&#xff0c;来回改了快半小时&#xff0c;要么字体太大挤在一起&#xff0c;要么颜色搭配显脏&#xff0c;运营催得急&…

深入理解 JVM 字节码文件:从组成结构到 Arthas 工具实践

在 Java 技术体系中&#xff0c;JVM&#xff08;Java 虚拟机&#xff09;是实现 “一次编写&#xff0c;到处运行” 的核心。而字节码文件作为 Java 代码编译后的产物&#xff0c;是 JVM 执行的 “原材料”。今天&#xff0c;我们就从字节码文件的组成结构讲起&#xff0c;再结…