小白到运维工程师自学之路 第三十八集 (redis高可用集群)

news2024/11/27 7:24:50

一、概述

        Redis高可用集群是一种分布式系统,它由多个Redis节点组成,可以提供高可用性和容错性。在Redis高可用集群中,每个节点都可以处理客户端请求,并且数据会在多个节点之间进行复制和同步,以确保数据的可靠性和一致性。当一个节点出现故障时,集群会自动将请求路由到其他可用节点,从而保证服务的连续性和可用性。Redis高可用集群通常使用主从复制和哨兵机制来实现数据的复制和故障检测,同时还可以使用分片技术来提高性能和扩展性。

二、工作原理

1. Sentinel集群中的每个Sentinel节点都会定期向Redis主从节点发送PING命令,以检测节点是否正常运行。

2. 如果一个Sentinel节点在一定时间内没有收到主节点的回复,它会将主节点标记为下线状态,并向其他Sentinel节点广播这个信息。

3. 当大多数Sentinel节点都认为主节点已经下线时,它们会选举一个Sentinel节点作为领导者,负责执行故障转移操作。

4. 领导者Sentinel节点会向所有从节点发送SLAVEOF命令,将它们切换为新的主节点的从节点。

5. 领导者Sentinel节点还会向新的主节点发送CONFIG SET命令,将它的IP地址和端口号更新到从节点的配置中。

6. 当从节点收到新的主节点的IP地址和端口号后,它们会重新连接到新的主节点,并开始同步数据。

三、准备工作

1、三台虚拟机

2、关闭防火墙

3、每台虚拟机都安装redis

4、三台虚拟机互通

四、部署

1、部署主服务器

vim /etc/redis.conf 编辑redis主配置文件

bind  0.0.0.0		表示任何人都可用
port 6379		    配置端口
daemonize yes		以守护进程模式启动

配置哨兵

vim /etc/redis-sentinel.conf  编辑哨兵配置文件

port 26379                                  哨兵的端口号
daemonize yes                               以守护进程启动
sentinel monitor mymaster 主服务器IP 6379 2  监控的IP端口号 名称sentinel通过投票后认为mater宕机的数量此处至少为两个
protected --mode no  	 关闭保护模式

 

 

 2、配置从服务器(两个从服务器的配置一样)

vim /etc/redis.conf         打开从服务器配置文件

bind  0.0.0.0		        表示任何人都可用
port 6379		            配置端口
daemonize yes		        以守护进程模式启动
slaveof 192.168.1.20 6379   主服务器的IP

 

 配置哨兵

vim /etc/redis-sentinel.conf      打开哨兵配置文件

port 26379                        端口号                    
daemonize yes                     以守护进程启动
sentinel monitor mymaster 主服务器IP 6379 2  监控的IP端口号 名称sentinel通过投票后认为mater宕机的数量此处至少为两个
protected --mode no  	          关闭保护模式

 

 

五、测试

现在可以看到我的主服务器下挂了两个从服务器

现在把主服务器停掉

 

 再去查看两个从服务器

IP为211的没有变化

但是可以发现IP为210的变成了主服务器

 

 以上测试结果为实验成功

这就是redis高可用集群的基本配置

如有错误欢迎各位大佬批评指正,我们共同进步

 

 

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

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

相关文章

Day_51-53kNN分类器

目录 Day_51:kNN分类器 一. 前言 二. 机器学习基本术语 三. kNN算法的原理 1. kNN算法的思想 2. kNN算法的具体实现过程 四. 代码实现 1. 导包 2. 参数初始化 3. 数据的导入 4. 数据的抽取 5. 对于测试集进行预测 6. 核心代码 Day_52:knn分类器&am…

LabVIEW开发微控制器控制的并行机器人的实时视觉图像处理

LabVIEW开发微控制器控制的并行机器人的实时视觉图像处理 通过相机视觉,以对目标物体的不同颜色进行分类,并与平行机器人一起拾取和放置物体。通过使用MATLAB Simulink模拟合适的机器人工作空间来研究使用相机的效率和机器人的准确性。机械臂以使用运动学…

OpenMMLab-AI实战营第二期——5-2. MMSegmentation代码课

文章目录 1. 自定义数据集1.0 整理数据集为特定格式1.1 持久化运行(用文件定义)1.2 运行时生效(直接运行时定义一个class)1.3 注意事项 2. 配置文件3. 运行训练和测试X. 其他语义分割数据集 视频链接:MMSegmentation代…

ThreadPoolExecutor源码

介绍 ThreadPoolExecutor 是 Java 中实现线程池的一个类,它是 ExecutorService 接口的一个实现类。线程池可以用来优化线程的使用,避免频繁地创建和销毁线程,以及限制并发线程的数量,从而提高应用程序的性能。 public class Thr…

读发布!设计与部署稳定的分布式系统(第2版)笔记06_用户

1. 系统的人类用户天生就具备进行创造性破坏的本事 1.1. 用户会消耗内存 1.2. 用户会做奇怪和随机的事情 1.2.1. fuzzing工具箱、基于属性的测试或模拟测试 1.3. 恶意用户总是存在的 1.3.1. 灾祸总会发生,坏人肯定存在 1.4. 用户会合伙对付你 2. 难伺候的用户…

【linux】opencv修改摄像头分辨率

起因 发现linux系统下调用opencv修改摄像头分辨率,一直修改不成功。 原本 正常在window下面读取摄像头数据是如下代码: # capture from web camcap cv2.VideoCapture(0)# set widthcap.set(3, 1280)# set heightcap.set(4, 720)while self._run_flag…

武职302303笔记-day01

这里写自定义目录标题 开发永和小票开发步骤1、对页面进行需求分析 使用CSS的方式 Order.html问题:html代码和css样式代码交织 idea开发后端程序使用chatGPT给我们打工QRCreate.java 开发永和小票 开发步骤 1、对页面进行需求分析 页面是很多文字组成,…

虹科分享丨如何保证我们的数据安全?|数据保护

一、数据安全 你可能已经正在寻找加密服务来帮助保护你的组织的数据,但如果你是一个不熟悉实践或管理数据的人员,"数据加密 "这个短语可能会感觉像技术术语或只是像一个模糊的概念,没有具体的解决方案。 但事实上,数据…

git、axios、模块化导出引入、promise、webpack、

GIT总结 git config --global user.name "你的用户名" git config --global user.email "你的邮箱" git config -l 命令来查看配置信息 git init 仓库初始化 touch index.html 创建index.html文件 git add index.html 文件加入暂存区 git add -A 将全部文件…

车载以太网 - 网络层 - IPv4/IPv6

目录 一、网络层基本信息介绍 1、网络协议适用范围 2、IPv4和IPv6的地址 3、Ethernet Frames 的类型 二、两种类型IP地址的定义: ECU通信的几种方式 路由器(Router)和IP 地址的概念 路由实例介绍 三、IPv4地址介绍 地址分类: 各类型IP可支持的最大网络数…

C语言实现移位密码

一.移位密码 移位密码(Caesar Cipher)也叫凯撒密码是一种简单的加密技术,它通过将明文中的每个字母按照指定的位数进行移位,从而生成密文。例如,在一个"左移3位"的移位密码中,文中的每个字母都向左移动3个位置&#xff…

7.2 SpringBoot实现上传图片API + url映射本地路径registry.addResourceHandler

文章目录 前言一、url映射本地路径二、上传图片API2.1 接口UploadService2.2 实现类UploadServiceImpl2.3 上传图片Controller 三、测试最后 前言 在图书借阅系统里,有很多图片需要前端展示,这些图片大都是由用户上传,保存在服务端&#xff…

chatgpt赋能python:Python拆数程序:如何快速分解数字?

Python拆数程序:如何快速分解数字? 在计算机编程中,数字拆分是一个非常重要的概念。拆分数字可以让我们更好地理解数字格式,进行计算和分析。而Python作为一种功能强大的编程语言,提供了许多高效的工具来帮助我们快速…

【备战秋招】每日一题:华东师范大学保研机试-2022-罗马数字

为了更好的阅读体检,可以查看我的算法学习博客罗马数字 题目内容 罗马数字是古罗马使用的记数系统,现今仍很常见。 罗马数字有七个基本符号: I,V,X,L,C,D,M。 罗马数字IVXLCDM对应的阿拉伯数字1510501005001000 需要注意的是罗马数字与十进位数字的…

chatgpt赋能python:Python拆分语句,让数据处理更有效率

Python 拆分语句,让数据处理更有效率 Python是一种强大的编程语言,不仅支持各种应用开发,而且非常适合数据处理。Python的易用性和灵活性使其成为了数据科学家和工程师首选的编程语言之一。Python的字符串拆分功能能够轻松处理数据的分割和组…

从C语言到C++_20(仿函数+优先级队列priority_queue的模拟实现+反向迭代器)

目录 1. priority_queue的模拟实现 1.1 未完全的priority_queue 1.2 迭代器区间构造和无参构造 1.3 仿函数的介绍和使用 1.4 完整priority_queue代码: 1.5 相关笔试选择题 答案: 2. 反向迭代器 2.1 反向迭代器的普通实现 reverse_iterator.h&a…

性能测试基础知识(一)性能测试策略

性能测试策略 一、什么是性能测试?二、性能测试的目的三、性能测试策略1、基准测试2、并发测试3、负载测试4、压力测试5、其他测试 一、什么是性能测试? 性能测试是在一定的负载1条件下,系统的响应时间等特性是否满足特定的性能需求。需要有…

软考A计划-系统集成项目管理工程师-信息化知识(二)

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例点击跳转>软考全系列 👉关于作者 专注于Android/Unity和各种游戏开发技巧&#xff…

【高危】Apache Nifi JMS组件存在JNDI反序列化漏洞

漏洞描述 Apache NiFi 是一个开源的数据流处理和自动化工具, JndiJmsConnectionFactoryProvider 控制器组件用于配置 JMS 连接地址。 Apache NiFi 1.8.0 至 1.21.0 版本中,由于 JndiJmsConnectionFactoryProvider 控制器服务允许已授权的用户配置 URL…

NUCLEO-F411RE RT-Thread 体验 (3) - GCC环境 uart驱动的移植以及console的使用

NUCLEO-F411RE RT-Thread 体验 (3) - GCC环境 uart驱动的移植以及console的使用 1、准备工作 在第一节里,我们用stm32cubemx将pa2 pa3管脚配置成usart2,用于跟st-link虚拟串口的打印用,那么我们先重定向printf函数,看这条通道是…