Redis

简介: Redis

Redis 快的原因


  1. 1.基于内存实现

  2. 2.高效的数据结构 : 简单动态字符串, 双端链表,压缩列表,字典,跳跃表

  3. 3.合理的数据编码

  4. 4.合适的线程模型 : I/O多路复用, 避免上下文切换,单线程模型


一. Redis是基于内存的数据库


Redis相对于磁盘数据库来说,省去了将数据I/O进内存的一个过程


二. 高效的数据结构


Redis有多种数据类型,每种数据类型的底层由一种或多种数据结构来支持。

20201023090950977.png

1. 简单动态字符串SDS

20201023091132560.png

在C语言中字符串的结尾以\0为结尾代表结束,如需获取字符串的全部信息就需要遍历。


Redis中用一个len字段记录当前字符串的长度,获取长度直接获取len。时间为O(1)


内存重新分配


C语言设计修改字符串会重新分配内存,频繁修该,内存分配就会频繁。内存分配会消耗性能。

在Redis 中设计到字符串频繁修改操作,就会采取两种优化策略: 空间预分配, 惰性空间释放。


(1)空间预分配 :


当字符串进行阔容得时候,除了分配锁必须的空间外,还会多分配一些未使用的空间。动态字符串修改之后,如果len长度大于1M, 就会额外分配与len相同长度的未使用空间。如果修改后长度大于1M, 将分配1M的使用空间。


(2)惰性空间释放 :


当动态字符串缩短的时候,并不会回收多余的内存空间,而是使用free字段将多出来的空间记录下来,如果后续有变更操作,就直接使用free中记录的空间,减少实际内存的分配改动。实际相当于一个伪删除


二进制安全


按照动态字符串存储的SDS的len变量直接进行读取,多出来的标志位字符是不会被读取的


2. 双端列表


2020102310101918.png

Redis实现了一个双端列表的结构。


(1)前后节点


链表里每个节点都带有两个指针,prev和next,prev指向前节点,next指向后节点,时间复杂度O(1)可以前向获取和后向获取。


(2)头尾节点


有了头尾几点,对双端节点的处理时间复杂度可以降至O(1),可以在队前加入并且还可以向后端进行操作。


(3)链表长度


长度可以通过世界获取储存的变量len, 时间复杂度降低至O(1)


3. 压缩列表

20201023101804589.png

当存储下数据的时候,不使用双端列表和额外的空间存储信息。用一个线性列表进行存储。压缩表的内存是连续分配的,遍历的速度非常快。在列表的头位置保存了

占用字节,偏移量(列表的长度), 节点的数量, 节点内容, 特殊标记符为结尾。

它是经过特殊编码,专门为了提升内存使用效率设计的。所有的操作都是通过指针与解码出来的偏移量进行的。


4. 字典


Redis 是 K-V型数据库,键值对是存在字典中的。


添加, 获取,删除都是O(1) 时间复杂度。


4. 跳表

20201023102423798.png

Redis中的跳表在链表的基础上增加了索引,使得查询效率提升。查询的时间复杂度为O(logN)。在头节点中存储相关信息。


三. 合理的数据编码


对于每一种数据类型来说,底层的支持可能是多种数据结构,什么时候使用哪种数据结构,这就涉及到了编码转化的问题。


那我们就来看看,不同的数据类型是如何进行编码转化的:


String:存储数字的话,采用int类型的编码,如果是非数字的话,采用 raw 编码;


List:字符串长度及元素个数小于一定范围使用 ziplist 编码,任意条件不满足,则转化为 linkedlist 编码;


Hash:hash 对象保存的键值对内的键和值字符串长度小于一定值及键值对;


Set:保存元素为整数及元素个数小于一定范围使用 intset 编码,任意条件不满足,则使用 hashtable 编码;


Zset:zset 对象中保存的元素个数小于及成员长度小于一定值使用 ziplist 编码,任意条件不满足,则使用 skiplist 编码。


四. 线程模型

20201023102700100.png

(1)I/O多路复用


  • I/O: 网络I/O

  • 多路:多个TCP连接

  • 复用:公用一个线程或进程


生产环境中的使用,通常是多个客户端连接 Redis,然后各自发送命令至 Redis 服务器,最后服务端处理这些请求返回结果。


应对大量的请求,Redis 中使用 I/O 多路复用程序同时监听多个套接字,并将这些事件推送到一个队列里,然后逐个被执行。最终将结果返回给客户端。


(2)使用单线程,减少上下文切换


不使用多线程,省去了上下文切换的过程。


(3)单线程

20201023103130752.png

Redis使用Reactor单线程模型。


总结


基于内存实现


数据都存储在内存里,减少了一些不必要的 I/O 操作,操作速率很快。


高效的数据结构


底层多种数据结构支持不同的数据类型,支持 Redis 存储不同的数据;


不同数据结构的设计,使得数据存储时间复杂度降到最低。


合理的数据编码


根据字符串的长度及元素的个数适配不同的编码格式。


合适的线程模型


I/O 多路复用模型同时监听客户端连接;


单线程在执行过程中不需要进行上下文切换,减少了耗时。




相关文章
|
3月前
|
数据采集 人工智能 API
AI 智能体项目的费用
AI智能体开发费用远超普通编程,涵盖人力(60%-70%)、算力(API或私有GPU年费15万+)、数据工程(3万-10万)及持续调优(年维护费≈开发费20%)。预算从3万元低代码起步,到百万级企业级方案不等。
|
6天前
|
人工智能 自然语言处理 文字识别
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
Qwen3.7-Max是阿里云百炼面向智能体时代推出的新一代旗舰模型,对标GPT-5.5、Claude Opus 4.7等闭源旗舰。该模型支持百万级token上下文窗口,具备顶级推理能力、多模态搜索与视觉理解增强、流式输出低延迟响应等核心优势,覆盖编程、办公、长周期自主执行等复杂场景。同时支持OpenAI接口兼容,便于系统快速迁移。用户可通过Token Plan团队或节省计划等订阅方式灵活调用,适合企业级高要求场景使用。
2934 10
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
|
13天前
|
人工智能 开发工具 iOS开发
Claude Code 新手完全上手指南:安装、国产模型配置与常用命令全解
Claude Code 是一款运行在终端环境中的 AI 编程助手,能够直接在命令行中完成代码生成、项目分析、文件修改、命令执行、Git 管理等开发全流程工作。它最大的特点是**任务驱动、终端原生、轻量高效、多模型兼容**,无需图形界面、不依赖 IDE 插件,能够深度融入开发者日常工作流。
3473 12
|
16天前
|
Shell API 开发工具
Claude Code 快速上手指南(新手友好版)
AI编程工具卷疯啦!Claude Code凭借任务驱动+终端原生的特性,成了开发者的效率搭子。本文从安装、登录、切换国产模型到常用命令,手把手带新手快速上手,全程避坑,30分钟独立用起来。
3559 25
|
10天前
|
人工智能 Linux BI
国内用 Claude Code 终于不用翻墙了:一行命令搞定,自动接 DeepSeek
JeecgBoot AI专题研究 一键脚本:Claude Code + JeecgBoot Skills + DeepSeek 全平台接入 一行命令装好 Claude Code + JeecgBoot Skills + DeepSeek 接入,无需翻墙使用 Claude Code,支持 Wind
2717 6
国内用 Claude Code 终于不用翻墙了:一行命令搞定,自动接 DeepSeek
|
7天前
|
人工智能 自然语言处理 供应链
|
7天前
|
人工智能 自然语言处理 安全
Claude Code 全攻略:命令大全+三种模式+记忆体系+实战工作流完整手册
Claude Code 是当前最流行的终端级 AI 编程助手,能够直接在命令行中完成代码生成、项目理解、文件修改、命令执行、错误修复等全流程开发工作。它不依赖图形界面、不占用额外资源,却能深度理解项目结构,自动生成规范代码,大幅提升研发效率。
1275 3
|
29天前
|
人工智能 JSON 供应链
畅用7个月无影 JVS Claw |手把手教你把JVS改造成「科研与产业地理情报可视化大师」
LucianaiB分享零成本畅用JVS Claw教程(学生认证享7个月使用权),并开源GeoMind项目——将JVS改造为科研与产业地理情报可视化AI助手,支持飞书文档解析、地理编码与腾讯地图可视化,助力产业关系图谱构建。
23612 15
畅用7个月无影 JVS Claw |手把手教你把JVS改造成「科研与产业地理情报可视化大师」