当前位置: 首页 > news >正文

揭秘Redis底层:一窥数据结构的奥秘与魅力

一、引言

Redis,以其高性能、高可靠、丰富的数据结构等特点,成为现代应用程序中不可或缺的缓存与存储组件。然而,Redis之所以能够实现如此卓越的性能,离不开其底层精巧的数据结构设计。本文将深入浅出地解析Redis底层五大核心数据结构——简单动态字符串(SDS)、链表、字典、跳跃表和整数集合,通过生动的比喻和实例,帮助读者理解其工作原理与应用场景,领略Redis强大性能背后的秘密。

二、简单动态字符串(SDS)

比喻: SDS如同一根可伸缩的橡皮筋,随时根据需要调整长度,既能保证数据安全存储,又能实现高效操作。

  1. 结构组成

    SDS由三部分构成:buf数组用于存储字符串内容,len记录已用空间长度,alloc记录已分配空间大小。这种设计使得SDS在执行字符串操作时无需额外的内存重分配,显著提升效率。

  2. 特性与优势

    • 避免缓冲区溢出:在进行字符串拼接等操作时,SDS会预分配多余空间,杜绝了传统C字符串可能导致的安全隐患。

    • O(1)复杂度操作:获取字符串长度、修改字符串等操作均能在常数时间内完成,优于C字符串的遍历计算。

    • 减少内存碎片:SDS的预分配策略与空间回收机制减少了内存碎片的产生。

三、链表

比喻: 链表好比一串手链,每个珠子(节点)独立存储数据并由线绳(指针)连接,灵活增删元素,适应动态变化。

  1. 节点结构

    链表节点包含数据域(value)和指针域(next),通过指针将各个节点串联起来,形成双向链表(双端链表)。

  2. 应用场景

    • 列表类型(List):实现列表的增删查改操作,如消息队列、微博时间线等。

    • 发布/订阅(Pub/Sub):维护频道订阅者链表,实现消息的发布与分发。

    • 监视器(Keyspace Notifications):使用链表存储待通知的客户端,以便在键空间事件发生时通知它们。

四、字典(哈希表)

比喻: 字典如同一本索引详尽的百科全书,通过“关键词”(键)迅速定位到对应的“词条”(值),实现高效查找与更新。

  1. 结构与实现

    字典使用哈希表(开放寻址法或拉链法)实现,包含两个哈希表结构table[2],用于rehash操作。每个哈希表由dictEntry节点组成,包含键、值、指向下个节点的指针。

  2. 特性与优化

    • 渐进式rehash:在rehash过程中,旧哈希表和新哈希表同时存在,分多次逐步迁移,避免一次性操作阻塞服务。

    • 惰性删除:删除操作仅标记节点为已删除,实际释放空间在后续操作中进行,减少CPU消耗。

    • 扩容与缩容策略:根据负载因子自动调整哈希表大小,维持查询效率。

五、跳跃表

比喻: 跳跃表犹如摩天大楼中的多层电梯系统,每一层电梯(层级)覆盖部分楼层(节点),高层电梯直达顶层,快速定位目标。

  1. 结构与查询

    跳跃表由多层有序链表构成,每层链表的节点数量逐层递减。查询时从顶层开始,沿着节点的前进指针向下搜索,直到找到目标或抵达底层。

  2. 应用场景与优势

    • 有序集合(Sorted Set):利用跳跃表实现数据的快速插入、删除、查询以及范围查询。

    • 近似有序:相比红黑树等复杂数据结构,跳跃表实现简单,性能优秀,且能保持数据近似有序。

    • 插入与查询效率:在平均情况下,跳跃表的插入、删除、查询时间复杂度均为O(logN),且实际性能往往优于红黑树。

六、整数集合(intset)

比喻: 整数集合好比一个精心分类的数字抽屉柜,每个抽屉(集合)存放特定范围的整数,便于管理和检索。

  1. 存储结构

    intset以紧凑型数组形式存储整数,根据元素大小自动升级数据类型(int16/int32/int64),保持数据紧凑且有序。

  2. 应用场景与优势

    • 集合类型(Set):当集合内元素为整数且数量较少时,intset比哈希表更节省空间,查询效率高。

    • 升级过程:新增元素导致类型升级时,intset能确保数据迁移的原子性,不影响其他客户端。

    • 范围查询:由于数据有序,支持快速的整数范围查询操作。

七、结语

Redis底层数据结构犹如精密的机械装置,各司其职,协同工作,共同铸就了Redis的高性能与高可靠性。理解并熟练运用这些数据结构,不仅能提升对Redis的驾驭能力,更能启发我们在日常开发中借鉴其设计理念,优化自家系统的数据结构设计,提升软件性能与效率。希望通过本文的讲解,读者能对Redis底层数据结构有更深入的理解,将其智慧应用到实际工作中,赋能业务发展。

相关文章:

揭秘Redis底层:一窥数据结构的奥秘与魅力

一、引言 Redis,以其高性能、高可靠、丰富的数据结构等特点,成为现代应用程序中不可或缺的缓存与存储组件。然而,Redis之所以能够实现如此卓越的性能,离不开其底层精巧的数据结构设计。本文将深入浅出地解析Redis底层五大核心数据…...

【网站项目】智能停车场管理系统小程序

🙊作者简介:拥有多年开发工作经验,分享技术代码帮助学生学习,独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。🌹赠送计算机毕业设计600个选题excel文件,帮助大学选题。赠送开题报告模板&#xff…...

芒果YOLOv5改进94:检测头篇DynamicHead为目标检测统一检测头:即插即用|DynamicHead检测头,尺度感知、空间感知、任务感知

该专栏完整目录链接: 芒果YOLOv5深度改进教程 该创新点:在原始的Dynamic Head的基础上,对核心部位进行了二次的改进,在 原论文 《尺度感知、空间感知、任务感知》 的基础上,在 通道感知 的层级上进行了增强,关注每个像素点的比重。 在自己的数据集上改进,有效涨点就可以…...

获奖名单出炉,OurBMC开源大赛总决赛圆满落幕

4 月 12 日,由开放原子开源基金会牵头、OurBMC 社区及理事长单位飞腾信息技术有限公司联合承办的 OurBMC 开源大赛总决赛在江苏宿迁圆满落幕。共有 10 支参赛队伍凭着初赛的优异表现进入决赛,在路演现场上演了一场精彩绝伦的对决。 江苏省工信厅软件和信…...

Qt配置外部库(Windows平台)

这里以C的外部库nlopt为例子来示范,右键工程选择添加库,然后选择库文件的目录(dll.a),会自动设置好包含路径(一般是include的目录),添加库(最下面一行) &…...

(最新)华为 2024 届实习招聘-硬件通⽤/单板开发——第十一套和十二套

(最新)华为 2024 届实习招聘-硬件通⽤/单板开发——第十一套和十二套 部分题目分享,完整版带答案(有答案和解析,答案非官方,未仔细校正,仅供参考)(共十套)获取&#xff…...

js纯前端实现语音播报,朗读功能(2024-04-15)

实现语音播报要有两个原生API 分别是【window.speechSynthesis】【SpeechSynthesisUtterance】 项目代码 // 执行函数 initVoice({text: 项目介绍,vol: 1,rate: 1 })// 函数 export function initVoice(config) {window.speechSynthesis.cancel();//播报前建议调用取消的函数…...

PostgreSQL数据库基础--简易版

数据库 其中runoobdb为数据库名 查看已经存在的数据库 \l进入数据库 \c runoobdb创建数据库 CREATE DATABASE runoobdb;删除数据库 DROP DATABASE runoobdb;表 其中COMPANY为表名 创建表格 CREATE TABLE COMPANY(ID INT PRIMARY KEY NOT NULL,NAME TEXT…...

前端解析URL的两种方式

方法一&#xff1a;利用 splice 分割 循环依次取出 方法一&#xff1a; function queryURLparams(url) {let obj {}if (url.indexOf(?) < 0) return objlet arr url.split(?)url arr[1]let array url.split(&)for (let i 0; i < array.length; i) {let arr2…...

Linux的学习之路:6、Linux编译器-gcc/g++使用

摘要 本文主要是说一些gcc的使用&#xff0c;g和gcc使用一样就没有特殊讲述。 目录 摘要 一、背景知识 二、gcc如何完成 1、预处理(进行宏替换) 2、编译&#xff08;生成汇编&#xff09; 3、汇编&#xff08;生成机器可识别代码 4、链接&#xff08;生成可执行文件或…...

分享2024 golang学习路线

写在前面 Go语言&#xff08;也称为Golang&#xff09;是Google开发的一种静态强类型、编译型语言&#xff0c;它具有简洁、快速、安全、并发等特点&#xff0c;尤其适合构建大型软件、微服务架构和云平台服务。Go的学习曲线相对平缓&#xff0c;社区活跃&#xff0c;是现代编…...

【Linux】进程间通信——system V版本 共享内存

目录 共享内存 原理 实践 shmget() 创建共享内存 shmctl() 删除共享内存 shmat() 挂接进程和共享内存 shmt() 进程和共享内存去关联 共享内存的特性 优势 劣势 用共享内存实现进程间通信 共享内存 原理 两个进程的PCB各自维护着一个进程地址空间。当两个进…...

【TEE论文】IceClave: A Trusted Execution Environment for In-Storage Computing

摘要 使用现代固态硬盘&#xff08;SSD&#xff09;的存储中计算使开发人员能够将程序从主机转移到SSD上。这被证明是缓解I/O瓶颈的有效方法。为了促进存储中计算&#xff0c;已经提出了许多框架。然而&#xff0c;其中很少有框架将存储中的安全性作为首要任务。具体而言&…...

【攻防世界】bug

垂直越权IP绕过文件上传 垂直越权 IP绕过 bp抓包&#xff0c;添加请求头X-Forwarded-For:127.0.0.1 文件上传 文件上传绕过&#xff1a; 1. mime检测&#xff08;Content-Type&#xff09; 2. 大小写绕过 3. 等价替换&#xff08;php5&#xff0c;php3&#xff09; 4. 利用J…...

详解UART通信协议以及FPGA实现

文章目录 一、UART概述二、UART协议帧格式2.1 波特率2.2 奇校验ODD2.3 偶校验EVEN 三、UART接收器设计3.1 接收时序图3.2 Verilog代码3.3 仿真文件测试3.4 仿真结果3.5 上版测试 四、UART发送器设计4.1 发送时序图4.2 Verilog代码4.3 仿真文件测试4.4 仿真结果4.5 上板测试 五、…...

【算法】删除链表中重复元素

本题来源---《删除链表中重复元素》。 题目描述 给定一个已排序的链表的头 head &#xff0c; 删除所有重复的元素&#xff0c;使每个元素只出现一次 。返回已排序的链表 。 示例 1&#xff1a; 输入&#xff1a;head [1,1,2] 输出&#xff1a;[1,2]示例 2&#xff1a; 输入…...

mysql防坑指南

1. MySQL连接数问题 MySQL里的max_connections参数代表mysql数据库的最大连接数&#xff0c;参数默认是151&#xff0c;显然不适用于生产&#xff0c;如果请求大于默认连接数&#xff0c;就会出现无法连接数据库的错误&#xff0c;会遇到too many connections的报错信息。 Mys…...

偏微分方程算法之混合边界差分

目录 一、研究对象 二、差分格式 2.1 向前欧拉格式 1. 中心差商 1.1.1 理论推导 1.1.2 算例实现 2. x0处向前差商&#xff0c;x1处向后差商 1.2.1 理论推导 1.2.2 算例实现 2.2 Crank-Nicolson格式 2.2.1 理论推导 2.2.2 算例实现 一、研究对象 这里我们以混合边界…...

中国八大古都,分别是哪8个?

中国历史上统一王朝或者在全局范围内看呈鼎立之势的大的政权的首都&#xff0c;称古都&#xff0c;又称都城、国都等&#xff0c;是古代王朝的政治中心&#xff0c;也是经济和文化中心。 1、西安 西安&#xff0c;古称长安&#xff0c;是中国历史上建都时间最长、建都朝代最多…...

财务信息化与财务软件有何区别与联系?

财务产品与财务信息化&#xff0c;两者究竟有何不同&#xff0c;又有何相通之处&#xff1f;或许&#xff0c;你心中也充满了这样的疑惑。那么&#xff0c;让我用一则小故事&#xff0c;为你揭晓其中的秘密。 想象这样一个场景&#xff0c;长尾狐狸&#xff0c;作为饭团公司的…...

Gemini3.1Pro如何使用代码教程

概要Gemini 3.1 Pro是Google DeepMind于2026年2月推出的旗舰级多模态大语言模型。ARC-AGI-2得分77.1%&#xff0c;SWE-Bench Verified 80.6%&#xff0c;GPQA Diamond 94.3%&#xff0c;在推理能力和代码生成上相比前代有明显提升。本文面向开发者&#xff0c;从零开始讲解Gemi…...

对抗机器学习实战:从模型脆弱性到工业级鲁棒性工程

1. 项目概述&#xff1a;当模型开始“看走眼”&#xff0c;我们该怎么办&#xff1f;你有没有遇到过这样的情况&#xff1a;一张清晰的猫图&#xff0c;被模型坚定地判为“烤面包”&#xff1b;一段语音指令&#xff0c;加了点人耳几乎听不出的杂音&#xff0c;智能音箱就把它理…...

四类高危漏洞的工程化修复:XSS、越权、反序列化与硬编码密钥治理

1. 这不是“打补丁”&#xff0c;而是重构安全认知的起点很多人把代码审计后的漏洞修复&#xff0c;当成开发流程末尾一个不得不做的收尾动作——改几行代码、加个过滤、套个函数&#xff0c;提交、测试、上线&#xff0c;完事。我干了十多年安全审核和开发支持&#xff0c;亲手…...

ISTA 3B-2013 全解析|零担货物 (LTL) 综合模拟运输测试标准(CSDN 完整版)前言

前言 ISTA 3B-2013 是 ISTA 3 系列高级综合模拟测试&#xff0c;专门针对零担货物运输&#xff08;LTL&#xff09; 的包装件。 零担运输的特点是多货混装、多次中转、人工 / 叉车交叉搬运、环境复杂&#xff0c;因此 3B 是工业、设备、家电、汽配、大型包装最贴近真实物流的测…...

【金蝶云星空】出纳做账-付款退款单使用场景

学习目标学习本内容后&#xff0c;您将掌握如何使用付款退款单。业务场景付款退款单 付款退款单与付款业务对应&#xff0c;处理付款业务所发生的退款&#xff0c;包括采购业务付款的退款或者其他业务付款的退款。支持手工新增或者关联应付系统负数的应付单、其他应付单生成付…...

SR全光谱反射式膜厚仪

作者&#xff1a;李志松Pioneer 翟天保Steven 田雨阳 版权声明&#xff1a;著作权归作者所有&#xff0c;商业转载请联系作者获得授权&#xff0c;非商业转载请注明出处注&#xff1a;本文所讲设备由李志松教授团队研发&#xff0c;属于商业产品矩阵内容&#xff0c;商业技术合…...

具身智能赋能:无感定位打破 UWB 传统空间交互局限

具身智能赋能&#xff1a;无感定位打破 UWB 传统空间交互局限人工智能技术向实体空间深度渗透&#xff0c;具身智能成为空间计算领域进阶发展的核心方向。区别于传统算法仅停留在数据层面分析决策&#xff0c;具身智能依托空间感知能力让智能体系拥有环境理解、自主交互、动态适…...

专业的郑州苹果手机维修联系电话口碑佳的

在当今数字化时代&#xff0c;苹果手机已成为人们生活中不可或缺的一部分。然而&#xff0c;手机使用过程中难免会出现各种故障&#xff0c;这时候选择一家专业靠谱的维修店就显得尤为重要。在郑州&#xff0c;果速修凭借其卓越的服务和良好的口碑&#xff0c;成为众多苹果用户…...

av1编码--比特流结构

目录 2.2.1 序列头信息 2.2.2 帧头信息 2.2.4 时间分隔符信息 2.2.5 切片组信息 AV1 比特流是由一系列名为开放比特流单元&#xff08;OBU&#xff09;的数据单元组成。每个 OBU 由一个可变长度的字节串&#xff08;Byte String&#xff09;组成。具体来讲&#xff0c;OBU 包…...

告别“感觉能用”:基于 Ragas 构建 RAG 自动化回归测试流水线的方法论

很多团队把 RAG 系统做到能演示、能回答、能接知识库之后,心里都会出现一种熟悉又危险的判断:看起来差不多能用了。 但只要系统真的进入业务场景,这种“差不多”很快就会露出问题。今天回答还算靠谱,明天换一批文档就开始飘;演示集表现很好,真实用户一多就出现答非所问;…...