【Java面试题】Redis中篇(高可用:主从复制、哨兵、集群)

文章目录

  • 高可用
    • 14.Redis如何保证高可用?
    • 15.Redis的主从复制?
    • 16.Redis主从有几种常见的拓扑结构?
    • 17.Redis的主从复制原理了解吗?
    • 18.说说主从数据同步的方式?
    • 19.主从复制存在的问题?
    • 20.Redis Sentinel(哨兵)了解吗?
    • 21.Redis Sentinel(哨兵)的实现原理?
    • 22.Redis集群了解吗?

高可用

14.Redis如何保证高可用?

Redis 保证高可用主要有三种方式:主从、哨兵、集群。

15.Redis的主从复制?

  1. 主从复制,是指将一台 Redis 服务器的数据,复制到其他的 Redis 服务器。前者称为 主节点(master),后者称为 从节点(slave)
  2. 且数据的复制是 单向 的,只能由主节点到从节点。Redis 主从复制支持 主从同步从从同步 两种,后者是 Redis 后续版本新增的功能,以减轻主节点的同步负担。

Redis主从复制简图

  1. 主从复制的作用?
    • 负载均衡 在主从复制的基础上,配合读写分离,可以由主节点提供写服务,由从节点提供读服务 (即写 Redis 数据时应用连接主节点,读 Redis 数据时应用连接从节点),分担服务器负载。尤其是在写少读多的场景下,通过多个从节点分担读负载,可以大大提高 Redis 服务器的并发量。
    • 故障恢复 当主节点出现问题时,可以由从节点提供服务,实现快速的故障恢复 (实际上是一种服务的冗余)
    • 数据冗余: 主从复制实现了数据的热备份,是持久化之外的一种数据冗余方式。
    • 高可用基石: 除了上述作用以外,主从复制还是哨兵和集群能够实施的 基础,因此说主从复制是 Redis 高可用的基础

16.Redis主从有几种常见的拓扑结构?

  1. Redis 的复制拓扑结构可以支持单层或多层复制关系,根据拓扑复杂性可以分为以下三种:一主一从、一主多从、树状主从结构。

    1. 一主一从结构:一主一从结构是最简单的复制拓扑结构,用于主节点出现宕机时从节点提供故障转移支持

      image-20240329095921273

    2. 一主多从结构(星形拓扑结构):使得应用端可以利用多个从节点实现读写分离。对于读占比较大的场景,可以把读命令发送到从节点来分担主节点压力。

      image-20240329095935427

    3. 树状主从结构(树状拓扑结构):使得从节点不但可以复制主节点数据,同时可以作为其他从节点的主节点继续向下层复制。通过引入复制中间层,可以有效降低主节点负载和需要传送给从节点的数据量。

      image-20240329100006480

17.Redis的主从复制原理了解吗?

  • Redis 主从复制的工作流程大概可以分为如下几步:
    1. 保存主节点(master)信息:这一步只是保存主节点信息,保存主节点的 ip 和 port。
    2. 主从建立连接:从节点(slave)发现新的主节点后,会尝试和主节点建立网络连接。
    3. 发送 ping 命令:连接建立成功后从节点发送 ping 请求进行首次通信,主要是检测主从之间网络套接字是否可用、主节点当前是否可接受处理命令。
    4. 权限验证:如果主节点要求密码验证,从节点必须正确的密码才能通过验证。
    5. 同步数据集:主从复制连接正常通信后,主节点会把持有的数据全部发送给从节点。
    6. 命令持续复制:接下来主节点会持续地把写命令发送给从节点,保证主从数据一致性

18.说说主从数据同步的方式?

  • Redis 在 2.8 及以上版本使用 psync 命令完成主从数据同步,同步过程分为:全量复制和部分复制

  • 全量复制:

    • 一般用于初次复制场景

    • Redis 早期支持的复制功能只有全量复制,它会把主节点全部数据一次性发送给从节点,当数据量较大时,会对主从节点和网络造成很大的开销。

    • 完全运行流程:

      image-20240329101256214

      1. 发送 psync 命令进行数据同步,由于是第一次进行复制,从节点没有复制偏移量和主节点的运行 ID,所以发送 psync-1。
      2. 主节点根据 psync-1 解析出当前为全量复制,回复+FULLRESYNC 响应。
      3. 从节点接收主节点的响应数据保存运行 ID 和偏移量 offset
      4. 主节点执行 bgsave 保存 RDB 文件到本地
      5. 主节点发送 RDB 文件给从节点,从节点把接收的 RDB 文件保存在本地并直接作为从节点的数据文件
      6. 对于从节点开始接收 RDB 快照到接收完成期间,主节点仍然响应读写命令,因此主节点会把这期间写命令数据保存在复制客户端缓冲区内,当从节点加载完 RDB 文件后,主节点再把缓冲区内的数据发送给从节点,保证主从之间数据一致性。
      7. 从节点接收完主节点传送来的全部数据后会清空自身旧数据
      8. 从节点清空数据后开始加载 RDB 文件
      9. 从节点成功加载完 RDB 后,如果当前节点开启了 AOF 持久化功能, 它会立刻做 bgrewriteaof 操作,为了保证全量复制后 AOF 持久化文件立刻可用。
  • 部分复制:部分复制主要是 Redis 针对全量复制的过高开销做出的一种优化措施, 使用 psync{runId}{offset}命令实现。当从节点(slave)正在复制主节点 (master)时,如果出现网络闪断或者命令丢失等异常情况时,从节点会向 主节点要求补发丢失的命令数据,如果主节点的复制积压缓冲区内存在这部分数据则直接发送给从节点,这样就可以保持主从节点复制的一致性。

19.主从复制存在的问题?

第一个问题是 Redis 的高可用问题,第二、三个问题属于 Redis 的分布式问题。

  • 高可用问题:一旦主节点出现故障,需要手动将一个从节点晋升为主节点,同时需要修改应用方的主节点地址,还需要命令其他从节点去复制新的主节点,整个过程都需要人工干预。
  • 分布式问题:主节点的写能力受到单机的限制。
  • 分布式问题:主节点的存储能力受到单机的限制。

20.Redis Sentinel(哨兵)了解吗?

  1. 主从复制存在一个问题,没法完成自动故障转移。所以我们需要一个方案来完成自动故障转移,它就是 Redis Sentinel(哨兵)

  2. Redis Sentinel ,它由两部分组成,哨兵节点和数据节点

    • 哨兵节点: 哨兵系统由一个或多个哨兵节点组成,哨兵节点是特殊的 Redis 节点,不存储数据,对数据节点进行监控。

    • 数据节点: 主节点和从节点都是数据节点;

      image-20240329101954973

  3. 在复制的基础上,哨兵实现了 自动化的故障恢复 功能,下面是官方对于哨兵功能的描述:

    1. 监控(Monitoring): 哨兵会不断地检查主节点和从节点是否运作正常。
    2. 自动故障转移(Automatic failover):主节点 不能正常工作时,哨兵会开始 自动故障转移操作,它会将失效主节点的其中一个 从节点升级为新的主节点,并让其他从节点改为复制新的主节点。
    3. 配置提供者(Configuration provider): 客户端在初始化时,通过连接哨兵来获得当前 Redis 服务的主节点地址。
    4. 通知(Notification): 哨兵可以将故障转移的结果发送给客户端。

21.Redis Sentinel(哨兵)的实现原理?

  1. 哨兵模式是通过哨兵节点完成对数据节点的监控、下线、故障转移

    image-20240329102848476

  2. 定时监控:三个定时监控任务完成对各个节点发现和监控:

    1. 每隔 10 秒,每个 Sentinel 节点会向主节点和从节点发送 info 命令获取最新的拓扑结构
    2. 每隔 2 秒,每个 Sentinel 节点会向 Redis 数据节点的sentinel:hello 频道上发送该 Sentinel 节点对于主节点的判断以及当前 Sentinel 节点的信息
    3. 每隔 1 秒,每个 Sentinel 节点会向主节点、从节点、其余 Sentinel 节点发送一条 ping 命令做一次心跳检测,来确认这些节点当前是否可达

    image-20240329102940302

  3. 主观下线/客观下线

    • 主观下线:一个哨兵节点认为某个节点有问题
      • 每个 Sentinel 节点会每隔 1 秒对主节点、从节点、其他 Sentinel 节点发送 ping 命令做心跳检测
      • 这些节点超过 down-after-milliseconds 没有进行有效回复,Sentinel 节点就会对该节点做失败判定,这个行为叫做主观下线。
    • 客观下线:超过一定数量的哨兵节点认为主节点有问题。
      • 当 Sentinel 主观下线的节点是主节点时,该 Sentinel 节点会通过 sentinel is- master-down-by-addr 命令向其他 Sentinel 节点询问对主节点的判断
      • 当超过 quorum 个数,Sentinel 节点认为主节点确实有问题,这时该 Sentinel 节点会做出客观下线的决定

    image-20240329103034117

  4. 领导者Sentinel节点选举

    • Sentinel 节点之间会做一个领导者选举的工作
    • 选出一个 Sentinel 节点作为领导者进行故障转移的工作。
    • Redis 使用了 Raft 算法实现领导者选举。
  5. 故障转移

    • 领导者选举出的 Sentinel 节点负责故障转移,过程如下:

      • 在从节点列表中选出一个节点作为新的主节点,这一步是相对复杂一些的一步
      • Sentinel 领导者节点会对第一步选出来的从节点执行 slaveof no one 命令让其成为主节点
      • Sentinel 领导者节点会向剩余的从节点发送命令,让它们成为新主节点的从节点
      • Sentinel 节点集合会将原来的主节点更新为从节点,并保持着对其关注,当其恢复后命令它去复制新的主节点

      image-20240329103721193

22.Redis集群了解吗?

  1. 前面说到了主从复制存在高可用和分布式的问题
  2. 哨兵解决了高可用的问题,而集群就是终极方案,一举解决高可用和分布式问题。

image-20240329103827998

  1. 数据分区 数据分区 (或称数据分片) 是集群最核心的功能。集群将数据分散到多个节点,一方面 突破了 Redis 单机内存大小的限制,存储容量大大增加另一方面 每个主节点都可以对外提供读服务和写服务,大大提高了集群的响应能力
  2. 高可用 集群支持主从复制和主节点的 自动故障转移 (与哨兵类似),当任一节点发生故障时,集群仍然可以对外提供服务

在这里插入图片描述

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

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

相关文章

信息素养和社会责任

1.信息素养: 信息素养是一种了解、收集、评估、和利用信息的知识结构能力。 信息素养的四个要素:信息意识,信息知识,信息能力,信息道德 信息意识是先导(前提),是对关键信息具有持…

elementui的table根据是否符合需求合并列

<el-table :data"tableData" border style"width: 100%;" :span-method"objectSpanMethodAuto"><!-- 空状态 --><template slot"empty"><div><img src"/assets/images/noData.png" /></di…

Opencv-光流算法-实战

0. 写在前面 理论介绍篇在&#xff1a;图像处理算法--光流法-原理-CSDN博客 2. Main函数代码 #include "mainwindow.h" #include "ui_mainwindow.h"#include <QFileDialog> #include <QLabel> #include <QDebug>MainWindow::MainWindo…

基于SSM+Jsp+Mysql的母婴用品网站

开发语言&#xff1a;Java框架&#xff1a;ssm技术&#xff1a;JSPJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包…

新能源汽车充电桩主板的常见故障及解决办法

电桩主板作为充电桩的核心组件&#xff0c;直接影响着充电桩运行的安全性与稳定性。然而&#xff0c;在使用过程中&#xff0c;充电桩主板会因多种原因而出现一些故障情况&#xff0c;了解这些原因并采取相应的应对方法对维护充电桩的正常运行起着至关重要的作用。接下来&#…

【LeetCode】合并两个有序数组

88. 合并两个有序数组 给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2&#xff0c;另有两个整数 m 和 n &#xff0c;分别表示 nums1 和 nums2 中的元素数目。 请你 合并 nums2 到 nums1 中&#xff0c;使合并后的数组同样按 非递减顺序 排列。 注意&#xff1a;最终&am…

3-zookeeper之ZAB协议

Zookeeper ZAB协议 概述 ZAB(Zookeeper Automic Broadcast)是一套专门为Zookeeper设计的用于进行原子广播和崩溃恢复的协议ZAB协议主要包含了两个功能 原子广播&#xff1a;保证数据一致性崩溃恢复&#xff1a;保证集群的高可用 ZAB协议本身是基于2PC算法来进行的设计&#…

Redis 红锁:分布式锁的强大实现

在分布式系统中&#xff0c;多个进程或线程可能需要并发访问共享资源。为了确保数据的一致性和正确性&#xff0c;我们需要一种分布式锁机制来协调这些访问。Redis 红锁就是这样一种强大的分布式锁实现。 一、分布式锁的概念 分布式锁是一种用于在分布式系统中实现资源互斥访…

U盘位置不可用,如何轻松应对数据恢复难题

在日常工作和生活中&#xff0c;U盘作为一种便捷的存储设备&#xff0c;经常被用于数据传输和备份。然而&#xff0c;有时我们可能会遇到这样一个问题&#xff1a;当插入U盘时&#xff0c;系统提示“位置不可用”或“无法访问”&#xff0c;这让人倍感困扰。面对这种情况&#…

wpsword求和操作教程

wpsword求和怎么操作&#xff1a; 1、首先&#xff0c;单纯的数据是无法求和的&#xff0c;所以我们必须要“插入”一个“表格” 2、接着将需要求和的数据填入到表格中。 3、填完后&#xff0c;进入“布局”选项卡。 4、然后打开其中的“公式” 5、在其中选择求和公式“SUM”并…

Go、Java、C++语言实现多态的方式

Go、Java、C语言实现多态的方式各有特色&#xff0c;但都遵循面向对象编程的基本原则。以下是各自实现多态的主要手段&#xff1a; Go语言&#xff1a; 虽然Go语言本身并不直接支持类和传统的面向对象继承&#xff0c;但它通过接口&#xff08;Interface&#xff09;实现了多态…

php高精度数学计算 - bc函数

PHP中的bc函数是用于高精度计算的函数&#xff0c;可以处理大数运算&#xff0c;支持加、减、乘、除、幂运算等。bc函数的语法如下&#xff1a; bc***(string $num1,string $num2, int $scale 0) : string参数说明&#xff1a; $num1&#xff1a;要进行计算的数值&#xff0c…

从0到1部署私域NuGet库:实战指南,让你轻松掌握!

引言 私域NuGet包的重要性&#xff1a;代码复用和团队协同。通过将公共组件、库或工具打包成NuGet包&#xff0c;并在私域中共享&#xff0c;团队成员可以更方便地引用和使用这些资源。其次私域NuGet包有助于依赖管理。通过私域NuGet包&#xff0c;团队可以集中管理这些依赖&a…

案例研究|DataEase实现物业数据可视化管理与决策支持

河北隆泰物业服务有限责任公司&#xff08;以下简称为“隆泰物业”&#xff09;创建于2002年&#xff0c;总部设在河北省高碑店市&#xff0c;具有国家一级物业管理企业资质&#xff0c;通过了质量体系、环境管理体系、职业健康安全管理体系等认证。自2016年至今&#xff0c;隆…

启信宝商业大数据助力全国经济普查

近日&#xff0c;合合信息旗下启信宝收到中国青年创业就业基金会感谢信&#xff0c;对启信宝协同助力全国经济普查和服务青年创业就业研究表达感谢。 第五次全国经济普查是新时代新征程上一次重大国情国力调查&#xff0c;是对国民经济“全面体检”和“集中盘点”&#xff0c;…

virtualbox 设置虚拟机 centos 网络

在VirtualBox中为运行CentOS系统的虚拟机配置网络连接&#xff0c;您通常可以选择以下几种网络模式之一&#xff0c;以满足不同的网络需求&#xff1a; NAT (Network Address Translation): 功能&#xff1a;允许虚拟机通过宿主机的网络连接访问互联网&#xff0c;同时也可以从…

学习鸿蒙基础(10)

目录 一、轮播组件 Swiper 二、列表-List 1、简单的List 2、嵌套的List 三、Tabs容器组件 1、系统自带tabs案例 2、自定义导航栏&#xff1a; 一、轮播组件 Swiper Entry Component struct PageSwiper {State message: string Hello Worldprivate SwCon: SwiperControl…

Ribbon简介

目录 一 、概念介绍 1、Ribbon是什么 2、认识负载均衡 2.1 服务器端的负载均衡 2.2 客户端的负载均衡 3、Ribbon工作原理 4、Ribbon的主要组件 IClientConfig ServerList ServerListFilter IRule Iping ILoadBalancer ServerListUpdater 5、Ribbon支持…

为什么Redis设计成单线程

Redis是单线程却能支持高并发 1.Redis 将数据存储在内存中&#xff0c;读取速度非常快&#xff0c;而写入操作通常采用异步持久化的方式&#xff0c;将数据定期写入到磁盘&#xff0c;避免了磁盘IO成为性能瓶颈。这样一来&#xff0c;Redis 可以在高速内存中快速响应读取请求&…

BGP实训

BGP基础配置实训 实验拓扑 注&#xff1a;如无特别说明&#xff0c;描述中的 R1 或 SW1 对应拓扑中设备名称末尾数字为 1 的设备&#xff0c;R2 或 SW2 对应拓扑中设备名称末尾数字为2的设备&#xff0c;以此类推&#xff1b;另外&#xff0c;同一网段中&#xff0c;IP 地址的主…