首页 > 数据库 >整理好了!2024年最常见 20 道 Redis面试题(四)

整理好了!2024年最常见 20 道 Redis面试题(四)

时间:2024-05-23 21:54:28浏览次数:25  
标签:面试题 20 单线程 Redis 复制 服务器 操作 执行

上一篇地址:整理好了!2024年最常见 20 道 Redis面试题(三)-CSDN博客

七、Redis 单线程模型是如何工作的?

Redis 是一个基于单线程模型的高性能键值存储数据库。尽管 Redis 操作大多数是单线程执行的,但它依然能够提供极高的性能,这主要得益于以下几个方面:

  1. 单线程模型

    • Redis 的所有操作都是在一个主线程中顺序执行的,这意味着在任何给定时刻,只有一个操作在处理,减少了多线程编程中的锁和同步开销。
  2. 事件驱动

    • Redis 使用事件驱动模型来处理客户端的请求和服务器的响应。这种模型允许 Redis 以非阻塞的方式处理多个客户端连接和请求。
  3. I/O 多路复用

    • Redis 利用了 I/O 多路复用技术,如 epoll(在 Linux 上)或 kqueue(在 BSD 系统上),这使得 Redis 能够同时监视多个套接字,以确定哪些套接字已经准备好进行读写操作。
    • 当一个套接字准备好进行操作时,Redis 会将该操作加入到事件循环中,由主线程顺序执行。
  4. 高效的数据结构

    • Redis 使用了高效的数据结构来存储键值对,如哈希表、跳表、压缩列表等,这些数据结构能够提供快速的查找、插入和删除操作。
  5. 内存管理

    • Redis 拥有精细的内存管理策略,包括内存分配、回收、碎片管理等,这有助于提高内存的使用效率。
  6. 无锁编程

    • 由于 Redis 是单线程的,它避免了多线程编程中常见的锁竞争和死锁问题,从而简化了编程模型并提高了性能。
  7. 原子操作

    • Redis 的操作是原子性的,这意味着每个操作要么完全执行,要么完全不执行,这有助于保证数据的一致性。
  8. 命令的优化

    • Redis 的命令执行是高度优化的,许多命令都是直接在内存中执行,无需进行磁盘 I/O 操作。
  9. 持久化操作的异步性

    • 虽然 Redis 是内存数据库,但它提供了持久化机制,如 RDB 快照和 AOF 日志。这些持久化操作通常是由子进程或后台线程异步执行的,不会阻塞主线程。
  10. 网络模型

    • Redis 使用自己的网络模型来处理客户端连接和请求,这使得它能够有效地管理大量并发连接。
  11. Pipelining

    • 客户端可以发送多个命令到 Redis,而不需要等待每个命令的响应,这种技术称为 Pipelining,可以显著提高客户端和服务器之间的通信效率。
  12. Lua 脚本

    • Redis 支持 Lua 脚本,允许用户在服务器端执行 Lua 脚本来执行复杂的操作,这些操作也是单线程执行的。

尽管 Redis 是单线程的,但通过上述机制,它能够提供非常高的性能和可伸缩性。然而,单线程模型也意味着 Redis 的性能受限于单个 CPU 核心的处理能力。对于需要高并发写入操作的应用,Redis 可能不是最佳选择,但对于读多写少的场景,Redis 可以提供非常出色的性能。

八、Redis 的主从复制是如何工作的?

Redis 的主从复制是一种高可用性解决方案,它允许多个 Redis 服务器(称为从服务器或副本)复制主服务器(称为主服务器或领导者)的数据。以下是 Redis 主从复制工作的详细过程:

  1. 复制的初始化

    • 主从复制开始于从服务器向主服务器发送 SLAVEOF 命令,指定主服务器的地址和端口。
    • 从服务器随后建立与主服务器的连接,并发送 PSYNC 命令请求数据同步。
  2. 数据同步

    • 如果从服务器是第一次复制,或者无法提供有效的复制偏移量,主服务器会执行一个 RDB 快照,并将整个数据库的数据发送给从服务器。
    • 如果从服务器已经复制过部分数据,PSYNC 命令会尝试进行部分重同步(如果主服务器支持的话)。这可以减少所需的数据传输量。
  3. RDB 快照传输

    • 主服务器生成 RDB 快照,并将该快照文件发送给从服务器。
    • 从服务器接收 RDB 文件,并将其加载到内存中,从而复制主服务器的数据。
  4. 命令传播

    • 在 RDB 快照同步完成后,主服务器继续将所有写操作命令发送给从服务器。
    • 从服务器接收这些命令,并在本地执行,以保持数据的一致性。
  5. 复制偏移量

    • 从服务器会记录它已经接收和执行的命令的数量,这个偏移量存储在从服务器的复制偏移量中。
    • 如果从服务器断开连接并重新连接,它会使用这个偏移量来请求从主服务器同步丢失的数据。
  6. 断线重连

    • 如果从服务器与主服务器之间的连接断开,从服务器会尝试自动重新连接。
    • 重连后,从服务器会发送 PSYNC 命令,尝试进行部分重同步,如果可能的话。
  7. 主服务器的故障转移

    • 在某些配置中,如果主服务器宕机,从服务器可以被提升为新的主服务器,这个过程称为故障转移或故障切换。
    • 这通常需要手动干预或使用自动化工具,如 Redis Sentinel 或 Redis Cluster。
  8. 读写分离

    • 在主从复制架构中,通常所有的写操作都在主服务器上执行,而读操作可以在从服务器上执行,以提高性能和可伸缩性。
  9. 配置和优化

    • 复制的配置和优化包括设置合适的 repl-ping-slave-period 和 repl-timeout 参数,以优化复制的稳定性和性能。
    • 还可以配置从服务器的 slave-read-only 参数,确保从服务器不接受写操作。
  10. 监控和日志

    • Redis 提供了多种监控复制状态的命令,如 INFO replication,以及日志记录功能,帮助管理员监控和诊断复制问题。

通过主从复制,Redis 可以提供数据的高可用性和读写分离,从而提高应用程序的性能和可靠性。然而,主从复制也带来了一些复杂性,如数据同步延迟、故障转移和数据一致性问题,需要在实际部署中仔细考虑和管理。

标签:面试题,20,单线程,Redis,复制,服务器,操作,执行
From: https://blog.csdn.net/weixin_38616368/article/details/139158644

相关文章

  • THUSC & APIO 2024 游记
    Day\(-\infty\)APIO被补录了?Day\(-\infty+1\)听说要报名THUSC?Day\(-\infty+10^9\)考完期中紧张地跑到机房来看看THU结果,结果学习CCF的左右(Day\(-\infty+10^9+1\)电脑一开屏保,上面赫然一行字:打印报到证-通过差点把心脏吓出来Day\(-1\)不想上whk,我......
  • 洛谷[普及]:P1149 [NOIP2008 提高组] 火柴棒等式
    [NOIP2008提高组]火柴棒等式感谢题目提供者CCF_NOI题目描述给你n 根火柴棍,你可以拼出多少个形如A+B=C 的等式?等式中的A、B、C 是用火柴棍拼出的整数(若该数非零,则最高位不能是0)。用火柴棍拼数字 的拼法如图所示:注意:1.加号与等号各自需要两根火柴棍;2.如果,则......
  • ccf 201409-2 画图
    http://t.csdnimg.cn/uJ2u9试题编号:201409-2试题名称:画图时间限制:1.0s内存限制:256.0MB问题描述:问题描述在一个定义了直角坐标系的纸上,画一个(x1,y1)到(x2,y2)的矩形指将横坐标范围从x1到x2,纵坐标范围从y1到y2之间的区域涂上颜色。下图给出了一个画了两个矩形的例子......
  • 程序分享--常见算法/编程面试题:分发糖果
    关注我,持续分享逻辑思维&管理思维&面试题;可提供大厂面试辅导、及定制化求职/在职/管理/架构辅导;有意找工作的同学,请参考博主的原创:《面试官心得--面试前应该如何准备》,《面试官心得--面试时如何进行自我介绍》, 《做好面试准备,迎接2024金三银四》。或关注博主免费专栏【程序......
  • Redis安装学习记录
    一、Redis介绍Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理。它支持字符串、哈希表、列表、集合、有序集合,位图,hyperloglogs等数据类型。内置复制、Lua脚本、LRU收回、事务以及不同级别磁盘持久化功能,同时通过RedisSentinel提供高可用......
  • 前端js面试题
    01.你能解释一下JavaScript中let和var的区别吗?答:“let”和“var”之间的主要区别是用“let”声明的变量具有块作用域,而用“var”声明的变量具有函数作用域。02.你能解释一下JavaScript中的闭包吗?答:闭包是一个函数,即使在父函数返回之后,它也可以访问其父作用域中的变量。......
  • CVE-2020-11981
    ApacheAirflowCelery消息中间件命令执行(CVE-2020-11981)ApacheAirflow是一款开源的,分布式任务调度框架。在其1.10.10版本及以前,如果攻击者控制了Celery的消息中间件(如Redis/RabbitMQ),将可以通过控制消息,在Worker进程中执行任意命令。漏洞环境依次执行如下命令启动airflow1.1......
  • CVE-2020-11978
    ApacheAirflow示例dag中的命令注入(CVE-2020-11978)ApacheAirflow是一款开源的,分布式任务调度框架。在其1.10.10版本及以前的示例DAG中存在一处命令注入漏洞,未授权的访问者可以通过这个漏洞在Worker中执行任意命令。漏洞复现cdvulhub/airflow/CVE-2020-11978#初始化数据库d......
  • 50-53-57 20240523
     50Shesawme,andwalkedover.Sheteeteredalittle,butitwasnotduetoheronde-tubercularleg.forherlimpwasalmostgone.teeter=towalkormoveunsteadilyorunsurely;totter;wobbletubercular=relatingtoorsufferingfromtuberculosis1这段文字描述......
  • 全球2023年自然科学指数(Nature Index),各单位排名表
    地址:https://www.nature.com/nature-index/annual-tables/2023/institution/all/all/global自然科学指数(NatureIndex)大揭秘!近日,自然指数官网更新自然指数排名数据(统计时间节点为2022.11.1-2023.10.31),中国高校表现依旧强势。统计结果显示,重庆大学进入全球排名TOP200,位列全球......