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

Redis--基础知识点--32--redis底层存储结构

Redis 数据库底层实现中,那个存储所有键值对的全局哈希表(dict),在运行过程中是会动态扩缩容的。


1. Redis 哈希表的结构特点

Redis 的数据库(如db->dict)底层使用的是dict 字典结构,它内部维护两个哈希表(ht[0] 和 ht[1]):

  • 平时只用 ht[0]。
  • 当需要扩容或缩容时,会分配一个 ht[1](大小是当前容量的 2 倍或 1/2 左右),然后渐进式地将 ht[0] 中的数据迁移到 ht[1],迁移完成后 ht[1] 成为新的 ht[0],旧的释放。

2. 触发扩容的条件

Redis 会检查负载因子

负载因子 = 哈希表中已有节点数 / 哈希桶的数量(size)
  • 自动扩容:当负载因子 ≥ 1,且 Redis 没有在执行bgsave/bgrewriteaof(即没有在后台持久化)时,就会触发扩容;如果正在持久化,负载因子需要达到5才扩容。
  • 扩容规则:新的哈希表大小为当前键值对数量 × 2并取最近的 2 的幂。比如当前有 3 个键,容量为 4,扩容后容量为 8。

3. 触发缩容的条件

当键值对被删除,哈希表变得很空时,Redis 也会自动缩容,以节约内存。

  • 自动缩容:当负载因子 < 0.1时,会触发缩容。
  • 缩容规则:新的哈希表大小就是当前键值对的数量,然后按 2 的幂取整(但不会小于 4,除非空表)。例如当前 2 个键,容量原来是 16,缩容后容量为 4。

4. 渐进式 rehash(不阻塞服务)

无论是扩容还是缩容,都不是一次性把所有键重新哈希,因为这样会导致 Redis 阻塞几秒甚至更久。

Redis 采用了渐进式 rehash

  • 在 rehash 期间,每次对哈希表的增删改查操作,都会顺便把当前操作对应的桶从 ht[0] 迁移到 ht[1]。
  • 此外,Redis 还会在空闲时间(serverCron 定时任务)主动迁移一批桶。
  • 这样整个迁移过程被分摊到多次请求中,每个请求只增加微小开销,客户端无感知

5. 手动控制(可选)

你也可以通过命令强制触发或调整 rehash 行为:

  • 手动触发 rehash:CONFIG SET activerehashing yes(默认开启)
  • 临时禁止 rehash:CONFIG SET activerehashing no(不推荐)
  • 查看当前的 rehash 进度:INFO stats中的total_active_defrag等字段,但 rehash 的具体状态需要看DEBUG OBJECTMEMORY STATS

⚠️ 一个容易混淆的点

不要把这个全局字典的动态扩缩容Redis 集群(Cluster)的节点扩缩容搞混:

  • 全局字典:单个 Redis 实例内部的哈希表自动 resize,默认就开启
  • Cluster 节点:是集群层面的节点增删,需要手动执行 resharding。

你问的是前者,Redis 内部确实是会动态扩缩容的,且这是其内存管理的重要特性之一。


如果你还想了解 rehash 期间如何同时访问两个哈希表、或者如何观测当前字典的扩容/缩容状态,我可以继续展开说明。

http://www.rkmt.cn/news/1417613.html

相关文章:

  • 告别VMware!在Ubuntu 22.04上用virt-manager图形化安装macOS Monterey保姆级教程
  • CVPR 2019 GWCNet实战:用PyTorch复现组相关立体匹配网络(附KITTI数据集训练技巧)
  • 2026年成都锦城学院深度解析:高考志愿填报场景信息不对称与择校焦虑痛点 - 品牌推荐
  • Veo 2 API密钥轮转机制失效全记录,企业级安全接入必须掌握的4个冷门配置项
  • 2026年近期,潍坊企业如何甄选SMETA咨询服务?青岛明阳华信专业解析与推荐 - 2026年企业资讯
  • Sora 2短视频爆款率提升217%的关键——不是提示词,而是时间戳语义对齐技术(已验证于107条百万播放视频)
  • Aurix TC397内存不够用?三种方法教你手动指定变量到PSRR、DSRR等不同地址空间
  • 2026辽阳市茅台酒回收服务评测:铁岭市五粮液回收/铁岭市生肖茅台回收/铁岭市经典五粮液回收/铁岭市陈年茅台回收/选择指南 - 优质品牌商家
  • 双图拼接实用指南,手机电脑不同操作方式与样式调整技巧 - 小有的家
  • D2RML魔法级多开:暗黑2重制版多账户一键启动的革命性体验
  • 2026 年 5 月证券从业备考避坑:从业与就业 APP 实测指南 - 讲清楚了
  • 用C语言面向对象思想,为STM32打造一个通用的IIC设备驱动库
  • Layuimini无限级菜单系统:构建企业级后台导航的终极指南
  • 2026年 化粪池厂家推荐排行榜:混凝土/三格/水泥预制化粪池,旱厕改造及农村家用化粪池优质品牌解析 - 品牌企业推荐师(官方)
  • 为开源AI工具OpenClaw配置Taotoken作为后端模型提供商
  • 新手如何合并两张图片?详细入门攻略手把手教你完成拼图 - 小有的家
  • Arduino Timer0中断对微秒级时序的影响与解决方案
  • Chaldea:FGO御主的终极智能游戏管家与战斗模拟器完整指南
  • 全能去水印软件分享,简单操作就能抹除视频各类水印 - 体验家
  • CentOS 7升级内核踩坑实录:手把手教你解决‘pstore: unknown compression: deflate’报错,顺利进系统
  • 保姆级教程:手把手教你进BIOS开启Intel VT-x,解决VMware报错(附7大品牌主板/笔记本实操)
  • Pythoncopy深拷贝与浅拷贝
  • 企业级AI选型决策模型(Claude专项版):融合LLM评估矩阵、RAG兼容度热力图与GDPR就绪度评分卡
  • 告别盲目下断点:Keil5调试效率翻倍的5个高级技巧与避坑指南
  • 低成本Ambisonic麦克风DIY:用USB声卡实现空间音频录制
  • 为什么很多企业项目,越来越需要“快速响应”能力?
  • 零数学基础入门AI的补课路径:不从头啃高数,而是按认证需求补
  • Sora 2 VR视频制作终极避坑清单(含12个已知bug编号、临时绕过方案及官方Patch ETA)
  • 为使用Claude Code的网站开发者,配置Taotoken稳定替代方案避免封号
  • C#控制台调用VISA踩坑实录:从‘找不到设备’到稳定通信,我都经历了什么?