redis集群配置(精华版):哨兵模式

哨兵模式

    • 概念
      • 单机单个哨兵
      • 多哨兵模式
    • 动手实操
      • 1、环境准备
      • 2、配置sentinel.conf配置文件
      • 3、启动哨兵&测试
      • 4、SpringBoot测试哨兵模式故障转移功能

概念

主从切换技术的方法是:当主服务器宕机后,需要手动把一台从服务器切换为主服务器,这就需要人工干预,费事费力,还会造成一段时间内服务不可用。这不是一种推荐的方式,更多时候,我们优先考虑哨兵模式

哨兵模式优缺点

优点:

  1. 哨兵集群,基于主从复制模式,所有主从复制的优点,它都有
  2. 主从可以切换,故障可以转移,系统的可用性更好
  3. 哨兵模式是主从模式的升级,手动到自动,更加健壮

缺点:

  1. Redis不好在线扩容,集群容量一旦达到上限,在线扩容就十分麻烦
  2. 实现哨兵模式的配置其实是很麻烦的,里面有很多配置项

单机单个哨兵

哨兵的作用:

  • 通过发送命令,让Redis服务器返回监控其运行状态,包括主服务器和从服务器。
  • 当哨兵监测到master宕机,会自动将slave切换成master,然后通过发布订阅模式通知其他的从服务器,修改配置文件,让它们切换主机

多哨兵模式

在这里插入图片描述

动手实操

1、环境准备

三台centos7虚拟机

节点IPPORT
LBJ192.168.3.1316379
slave01192.168.3.1376379
slave02192.168.3.1386379
/192.168.3.13126379
/192.168.3.13726379
/192.168.3.13826379

默认已经都安装好redis了,redis默认安装路径在/usr/local/bin,我分别在三台服务器的redis安装目录下,创建了一个kconfig文件夹存放redis.confsentinel.conf

在这里插入图片描述

2、配置sentinel.conf配置文件

  • 按照主从复制模式,搭建一主两从
  • 192.168.3.131 为主服务器,192.168.3.137、192.168.3.138 为从服务器,在上一篇文章中,已搭建好主从模式
  • 一主二从都分别搭建哨兵节点

1)禁止保护模式
在这里插入图片描述

2) sentinel monitor mymaster 127.0.0.1 6379 2

其中mymaster为监控对象起的服务器名称,可以自定义,ip地址:监控的主服务,端口为master 服务器port, 2表示至少有多少个哨兵同意迁移的数量,即2个以上哨兵认为主服务器不可以用事,才进行客观下线。单个哨兵监测到主服务不可用,仅仅只是主观下线,需要客观下线才算数

在这里插入图片描述

  • 修改sentinel.conf 将 默认的sentinel monitor mymaster 127.0.0.1 6379 2 改为
    sentinel monitor mymaster 192.168.3.131 6379 2

3)sentinel auth-pass mymaster 123456

由于我们的主服务器设置了密码,所以需要手动配置一下

sentinel auth-pass mymaster 123456

3、启动哨兵&测试

此处默认主从模式已经部署,同时redis已经开启

1)分别启动所有节点的哨兵

redis-sentinel kconfig/sentinel.conf

在这里插入图片描述

可以看到哨兵监听到主服务器

2)关闭主服务器,查看哨兵信息

在这里插入图片描述

我们可以发现192.168.3.131主服务不可用了,过了30秒,哨兵模式 投票 将 从服务器 192.168.3.137选举为主服务器

这里面的有一个时间间隔,实际上是服务下线修复的时间,可以在sentinel.conf配置文件里配置

sentinel down-after-milliseconds <master-name> <milliseconds>,默认:30s

3)重启原本宕机的主服务

在这里插入图片描述

在这里插入图片描述

由于137已经成为master了,重新回来的131,只能当slave

但是原本宕机,现在重新加入的节点,还无法同步最新master的状态

在这里插入图片描述

131继续宕机,也只是作为slave宕机,137哨兵会监测到,并主观下线131

在这里插入图片描述

​ 在Redis的哨兵模式下当一个主服务器宕机后重新开启,并且成为一个从服务器(slave),它不会自动同步新的主服务器(master)的状态,这是因为Redis的复制机制是单向的。换句话说,一个从服务器只能复制主服务器的数据,而不能向主服务器发送数据

当一个主服务器重新启动后成为从服务器,它会尝试连接之前的主服务器(即它断开连接之前的主服务器),并尝试从该主服务器那里进行同步。如果之前的主服务器仍然可用并且数据没有被清除,那么重新启动的从服务器会尝试复制之前的主服务器的数据,而不会连接到新的主服务器

解决这个问题,可以通过以下步骤来手动配置重新启动的从服务器以连接到新的主服务器

  1. 在重新启动的从服务器上,修改配置文件,将新的主服务器的地址和端口更新为主服务器的地址和端口。

  2. 重启从服务器,使其连接到新的主服务器并开始同步数据。

  3. 确保重新启动的从服务器可以与新的主服务器建立连接并成功同步数据。可以通过监视从服务器的日志文件或使用Redis命令检查同步状态。

  4. 如果有必要,可以重新配置哨兵以将重新启动的从服务器纳入监控,并在必要时进行故障转移。

通过执行以上步骤,重新启动的从服务器应该能够成功连接到新的主服务器并同步数据,从而与新的主服务器保持同步状态

4) 完整的哨兵模式配置文件 sentinel.conf

# Example sentinel.conf# 哨兵sentinel实例运行的端口 默认26379
port 26379# 哨兵sentinel的工作目录
dir /tmp# 哨兵sentinel监控的redis主节点的 ip port 
# master-name  可以自己命名的主节点名字 只能由字母A-z、数字0-9 、这三个字符".-_"组成。
# quorum 当这些quorum个数sentinel哨兵认为master主节点失联 那么这时 客观上认为主节点失联了
# sentinel monitor <master-name> <ip> <redis-port> <quorum>
sentinel monitor mymaster 127.0.0.1 6379 1# 当在Redis实例中开启了requirepass foobared 授权密码 这样所有连接Redis实例的客户端都要提供密码
# 设置哨兵sentinel 连接主从的密码 注意必须为主从设置一样的验证密码
# sentinel auth-pass <master-name> <password>
sentinel auth-pass mymaster MySUPER--secret-0123passw0rd# 指定多少毫秒之后 主节点没有应答哨兵sentinel 此时 哨兵主观上认为主节点下线 默认30秒
# sentinel down-after-milliseconds <master-name> <milliseconds>
sentinel down-after-milliseconds mymaster 30000# 这个配置项指定了在发生failover主备切换时最多可以有多少个slave同时对新的master进行 同步,
这个数字越小,完成failover所需的时间就越长,
但是如果这个数字越大,就意味着越 多的slave因为replication而不可用。
可以通过将这个值设为 1 来保证每次只有一个slave 处于不能处理命令请求的状态。
# sentinel parallel-syncs <master-name> <numslaves>
sentinel parallel-syncs mymaster 1# 故障转移的超时时间 failover-timeout 可以用在以下这些方面: 
#1. 同一个sentinel对同一个master两次failover之间的间隔时间。
#2. 当一个slave从一个错误的master那里同步数据开始计算时间。直到slave被纠正为向正确的master那里同步数据时。
#3.当想要取消一个正在进行的failover所需要的时间。  
#4.当进行failover时,配置所有slaves指向新的master所需的最大时间。不过,即使过了这个超时,slaves依然会被正确配置为指向master,但是就不按parallel-syncs所配置的规则来了
# 默认三分钟
# sentinel failover-timeout <master-name> <milliseconds>
sentinel failover-timeout mymaster 180000# SCRIPTS EXECUTION#配置当某一事件发生时所需要执行的脚本,可以通过脚本来通知管理员,例如当系统运行不正常时发邮件通知相关人员。
#对于脚本的运行结果有以下规则:
#若脚本执行后返回1,那么该脚本稍后将会被再次执行,重复次数目前默认为10
#若脚本执行后返回2,或者比2更高的一个返回值,脚本将不会重复执行。
#如果脚本在执行过程中由于收到系统中断信号被终止了,则同返回值为1时的行为相同。
#一个脚本的最大执行时间为60s,如果超过这个时间,脚本将会被一个SIGKILL信号终止,之后重新执行。#通知型脚本:当sentinel有任何警告级别的事件发生时(比如说redis实例的主观失效和客观失效等等),将会去调用这个脚本,
#这时这个脚本应该通过邮件,SMS等方式去通知系统管理员关于系统不正常运行的信息。调用该脚本时,将传给脚本两个参数,
#一个是事件的类型,
#一个是事件的描述。
#如果sentinel.conf配置文件中配置了这个脚本路径,那么必须保证这个脚本存在于这个路径,并且是可执行的,否则sentinel无法正常启动成功。
#通知脚本
# sentinel notification-script <master-name> <script-path>sentinel notification-script mymaster /var/redis/notify.sh# 客户端重新配置主节点参数脚本
# 当一个master由于failover而发生改变时,这个脚本将会被调用,通知相关的客户端关于master地址已经发生改变的信息。
# 以下参数将会在调用脚本时传给脚本:
# <master-name> <role> <state> <from-ip> <from-port> <to-ip> <to-port>
# 目前<state>总是“failover”,
# <role>是“leader”或者“observer”中的一个。 
# 参数 from-ip, from-port, to-ip, to-port是用来和旧的master和新的master(即旧的slave)通信的
# 这个脚本应该是通用的,能被多次调用,不是针对性的。
# sentinel client-reconfig-script <master-name> <script-path>
sentinel client-reconfig-script mymaster /var/redis/reconfig.sh

4、SpringBoot测试哨兵模式故障转移功能

先关闭所有的redis主从节点和哨兵节点,重启发现,137依然还是master,说明故障转移后,主从关系确定下来后,将不再发生变化

在这里插入图片描述

初始状态,键值对情况

在这里插入图片描述

1)application.yml

spring:redis:# 配置哨兵sentinel:# 主服务器名称master: mymaster# 哨兵节点nodes: 192.168.3.131:26379,192.168.3.137:26379,192.168.3.138:26379# 登录密码password: 123456# Jedis配置jedis:# 连接池配置pool:# 最大等待1秒max-wait: 1s# 最大空闲连接数max-idle: 10# 最大活动连接数max-active: 20# 最小空闲连接数min-idle: 5# 配置Redis集群信息cluster:# 集群节点信息nodes: 192.168.3.131:6379,192.168.3.137:6379,192.168.3.138:6379# 最大重定向数,一般设置为5,# 不建议设置过大,过大容易引发重定向过多的异常max-redirects: 5password: 123456

2)controller

    @GetMapping("/test")public String test() {return "test";}// 注入StringRedisTemplate对象,该对象操作字符串,由Spring Boot机制自动装配@Autowiredprivate StringRedisTemplate stringRedisTemplate = null;// 测试Redis写入@GetMapping("/write")public Map<String, String> testWrite() {Map<String, String> result = new HashMap<>();result.put("666LBJ666", "value1");stringRedisTemplate.opsForValue().multiSet(result);return result;}// 测试Redis读出@GetMapping("/read")public Map<String, String> testRead() {Map<String, String> result = new HashMap<>();result.put("666LBJ666", stringRedisTemplate.opsForValue().get("666LBJ666"));return result;}

3)写入键值对

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

4)当137master宕机,测试是否可以故障转移,并保证可用

在这里插入图片描述

在这里插入图片描述

删掉刚写入的键值对

在这里插入图片描述

再次请求,写入

在这里插入图片描述

在这里插入图片描述

5)读取一下键值对

在这里插入图片描述

至此redis-哨兵模式搭建与测试功能完毕

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

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

相关文章

无人驾驶矿卡整体解决方案(5g物联网通信方案)

​无人驾驶矿卡是智能矿山的重要组成部分,通过远程操控替代人工驾驶,可以显著提高采矿效率和作业安全性。但要实现无人驾驶矿卡,需要依赖于可靠高效的通信网络,来传输现场视频、控制指令和运行数据。以下是某大型煤矿在部署无人驾驶矿卡时,所采用的星创易联物联网整体解决方案。…

【C++的奇迹之旅】C++关键字命名空间使用的三种方式C++输入输出命名空间std的使用惯例

文章目录 &#x1f4dd;前言&#x1f320; C关键字(C98)&#x1f309; 命名空间&#x1f320;命名空间定义&#x1f309;命名空间使用 &#x1f320;命名空间的使用有三种方式&#xff1a;&#x1f309;加命名空间名称及作用域限定符&#x1f320;使用using将命名空间中某个成员…

第十四届蓝桥杯JavaA组省赛真题 - 特殊日期

解题思路&#xff1a; 暴力秒了 public class Main {public static void main(String[] args) {int cnt 0;for (int i 1900; i < 9999; i) {for (int j 1; j < 12; j) {for (int k 1; k < days(i, j); k) {if (sum(i) sum(j) sum(k)) cnt;}}}System.out.print…

Nginx漏洞之未授权访问和源码泄漏漏洞处理

一、漏洞描述 某次安全扫描&#xff0c;发现某平台存在资源&#xff1a;未授权访问和源码泄漏&#xff1b;攻击者可能获取到网站的配置文件、敏感数据存储位置和访问凭证等信息。这意味着攻击者可以获得对网站的完全或部分控制权&#xff0c;进而进行恶意篡改、删除或添加恶意…

Linux-进程控制

&#x1f30e;进程控制【上】 文章目录&#xff1a; 进程控制 为什么要有地址空间和页表 程序的内存       程序申请内存使用问题 写时拷贝与缺页中断 父子进程代码共享       为什么需要写时拷贝       页表的权限位       缺页中断 退出码和错误码…

SpringBoot 登录认证(二)

SpringBoot 登录认证&#xff08;一&#xff09;-CSDN博客 SpringBoot 登录认证&#xff08;二&#xff09;-CSDN博客 SpringBoot登录校验&#xff08;三&#xff09;-CSDN博客 HTTP是无状态协议 HTTP协议是无状态协议。什么又是无状态的协议&#xff1f; 所谓无状态&…

毅速丨一体化压铸浪潮涌动 3D打印压铸模具将迎来广泛应用

近年来&#xff0c;特斯拉等车企的革新步伐引领着汽车制造业的变革&#xff0c;车身一体化压铸技术日益凸显其地位。这一技术不仅简化了车身制造的繁琐流程&#xff0c;更在供应链整合上实现了革命性的突破&#xff0c;为汽车制程带来了前所未有的经济性提升。 压铸技术&#x…

【面试那些事儿】浏览器键入网址到网页显示,期间发生了什么

当用户在浏览器中键入网址并按下回车键后&#xff0c;直到最终显示出完整的网页内容&#xff0c;这一过程中经历了哪些步骤呢&#xff1f; 这是一道经典的面试题&#xff0c;我们来看看具体有哪些阶段。 1. 解析URL 浏览器首先解析用户输入的URL&#xff0c;判断它的语法和协…

大话设计模式之策略模式

策略模式是一种行为设计模式&#xff0c;它允许在运行时选择算法的行为。这种模式定义了一族算法&#xff0c;将每个算法都封装起来&#xff0c;并且使它们之间可以互相替换。 在策略模式中&#xff0c;一个类的行为或其算法可以在运行时改变。这种模式包含以下角色&#xff1…

flume配置文件后不能跟注释!!

先总结&#xff1a;Flume配置文件后面&#xff0c;不能跟注释&#xff0c;可以单起一行写注释 报错代码&#xff1a; [ERROR - org.apache.flume.SinkRunner$PollingRunner.run(SinkRunner.java:158)] Unable to deliver event. Exception follows. org.apache.flume.EventDel…

2024跨境电商新型选品方法

是不是有很多卖家一到旺季就为选品发愁&#xff1f;担心选错产品或是错过机会&#xff1f;今天就给大家打开思路&#xff0c;分享2024更好用的选品方法&#xff0c;解决大家的选品难题&#xff01; 2024跨境电商新型选品方法 1️⃣ 本土卖家观察法 利用社交媒体平台如Instagram…

Linux系统中安装一些常用的插件备用

Linux系统中安装一些常用的插件备用 1.安装wget yum -y install wget 2.安装vim yum -y install vim-enhanced 3.更换yum源为国内的阿里云源&#xff08;选择&#xff09; 1、备份CentOS-Base.repo mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.…

3d智慧火电厂可视化管理平台提升企业的经济效益

在数字化时代的浪潮中&#xff0c;我们迎来了一个崭新的概念——“智慧火力火电厂”。这一创新理念将前沿信息技术与传统的火力发电工艺完美融合&#xff0c;引领着电力生产与管理的深刻变革。 火电厂3D可视化展示系统融合了数字孪生、3D可视化、物联网、人工智能和大数据等尖端…

PN8034芯朋微PN8034SSC-R1B非隔离SOP7封装12V300MA电源芯片

PN8034集成PFM控制器及650V高雪州能力智能功本MOSFET&#xff0c;用于外图元器件极精简的小功本非隔离开关电源。PN8034内置高压启动模块&#xff0c;实现系统快速启动&#xff0c;超低待机功能。该芯片提供了完整的智能化保护功能&#xff0c;包括过流保护&#xff0c;欠压保护…

【Python】python2.7升级到python3.x

这里写目录标题 1.检查当前python版本2.下载最新的python3. pip安装4.系统默认python调整5 .错误 1.检查当前python版本 python -v2.下载最新的python python下载地址&#xff1a; wget https://www.python.org/ftp/python/3.12.2/Python-3.12.2.tar.xz进行解压 tar -xvf P…

设计模式——结构型——外观模式Facade

处理器类 public class Cpu {public void start() {System.out.println("处理器启动了...");} } 内存类 public class Memory {public void start() {System.out.println("内存启动了...");} } 硬盘类 public class Disk {public void start() {Syste…

接口自动化测试框架:Junit5+RestAssured+Allure

需求分析 需求点需求分析通过 yaml 配置接口操作和用例后续新增接口和测试用例只需要编写 yaml 文件即可实现。可以支持接口间的参数传递具有参数依赖的接口可以进行变量的抽取和参数赋值。支持全局、用例维度的变量存储比如时间截命名法中要用到的时间截后缀。支持用例软断言…

Mysql从0到1 —— CRUD/索引/事务

文章目录 1 预备知识1.1 安装1.2 登录 & 退出1.3 配置文件my.cnf 2 基础知识2.1 链接服务器2.2 什么是数据库2.3 基本使用2.3.1创建表2.3.2 插入数据 2.4 服务器、数据库、表的关系2.5 SQL分类2.6 存储引擎 3 Mysql数据库的操作3.1 创建和删除3.2 字符集和校验规则3.3 查看…

【Spring源码】WebSocket做推送动作的底层实例

一、前瞻 Ok&#xff0c;开始我们今天的对Spring的【模块阅读】。 那就挑Web里的WebSocket模块&#xff0c;先思考下本次阅读的阅读线索&#xff1a; WebSocket在Spring里起到什么作用这个模块采用了什么设计模式我们都知道WebSocket可以主动推送消息给用户&#xff0c;那做推…

Spring Boot 统一数据返回格式 分析 和 处理

目录 实现统一数据格式 测试 原因分析 解决方案 &#x1f3a5; 个人主页&#xff1a;Dikz12&#x1f4d5;格言&#xff1a;吾愚多不敏&#xff0c;而愿加学欢迎大家&#x1f44d;点赞✍评论⭐收藏 实现统一数据格式 统⼀的数据返回格式使⽤ ControllerAdvice 和 Response…