一、基础内存模型

  1. 指针包装

    • 所有 JSON 值(标量、对象、数组、字符串等)至少占用 8 字节,用于存储一个带类型标记的指针。
  2. 标量与空容器

    • nulltruefalse、小整数(静态缓存)、空字符串、空数组、空对象 均不分配额外内存,仅用上述 8 字节指针指向静态实例。

二、字符串存储

  • 额外字节消耗 = 字符串长度

  • 示例:存储 "bar"(3 字节)

    JSON.SET foo . '"bar"'  
    JSON.DEBUG MEMORY foo → 11 字节(8 + 3)  
    

三、数组的几何增长

  • 初始容量:4

  • 元数据:16 字节(8 字节容量,8 字节当前长度)

  • 指针包装:8 字节

  • 元素指针数组capacity × 8 字节

  • 示例

    • 1–4 个元素 → 8 + 16 + 4×8 = 56 字节
    • 第 5 个元素触发扩容至 8 → 8 + 16 + 8×8 = 88 字节

四、磁盘文件存储对比

测试文件原始 JSON 大小RedisJSON 占用MessagePack 占用
pass-100.json (380 B)381 B1,069 B140 B
pass-jsonsl-1.json (1.4 KB)1,387 B2,190 B757 B
pass-json-parser-0000.json (3.7 KB)3,718 B5,469 B2,393 B
pass-jsonsl-yahoo2.json (22 KB)22,466 B26,901 B16,869 B
pass-jsonsl-yelp.json (46 KB)46,333 B57,513 B35,529 B

提示:删除数组或对象中的元素并不会自动释放已分配的内存。

五、全局字符串重用机制

  • Redis 内核对相同字符串内容只存一份物理内存,多处引用。
  • JSON.DEBUG MEMORY 报告时仍按逻辑实例“各自”计算,可能显著高于实际物理占用。

六、调优建议

  1. 小字符串优先:尽量避免超长文本字段,或分割存储;
  2. 合理预分配数组:对大数组可预先 JSON.SET 一个空数组并扩容到合适长度,减少中间扩容次数;
  3. 字段重用:对重复出现的关键字或枚举值,依赖 Redis 全局字符串重用降低物理占用;
  4. 监控内存:定期使用 JSON.DEBUG MEMORYMEMORY USAGE 对比物理报告,识别潜在内存膨胀;
  5. 版本升级:关注新版 RedisJSON 的优化与内存改进,及时升级。

通过以上剖析与对比,您可以更精准地评估和控制 RedisJSON 在生产环境中的内存消耗,并制定高效的存储与访问策略。

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

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

相关文章

【LeetCode 热题 100】23. 合并 K 个升序链表——(解法一)逐一合并

Problem: 23. 合并 K 个升序链表 题目:给你一个链表数组,每个链表都已经按升序排列。 请你将所有链表合并到一个升序链表中,返回合并后的链表。 文章目录整体思路完整代码时空复杂度时间复杂度:O(K * N)空间复杂度:O(1…

垃圾收集器-Serial Old

第一章 引言1.1 JVM 中垃圾收集的简要概述JVM(Java Virtual Machine)作为 Java 程序的运行时环境,负责将字节码加载至内存并执行,同时也承担着内存管理的重任。垃圾收集(Garbage Collection,简称 GC&#x…

Docker(02) Docker-Compose、Dockerfile镜像构建、Portainer

Docker-Compose 1、Docker Desktop 在Windows上安装Docker服务,可以使用Docker Desktop这个应用程序。 下载并安装这样的一个安装包 安装好后:执行命令 docker --version 从Docker Hub提取hello-world映像并运行一个容器: docker run h…

大数据时代UI前端的用户体验设计新思维:以数据为驱动的情感化设计

hello宝子们...我们是艾斯视觉擅长ui设计和前端数字孪生、大数据、三维建模、三维动画10年经验!希望我的分享能帮助到您!如需帮助可以评论关注私信我们一起探讨!致敬感谢感恩!一、引言:从 “经验设计” 到 “数据共情” 的体验革命传统 UI 设计常陷入 “设计师主观经…

TypeScript 学习手册

1.TypeScript 概念 TypeScript(简称 TS,静态类型)是微软公司开发的一种基于 JavaScript (简称 JS,动态类型)语言的编程语言。TypeScript 可以看成是 JavaScript 的超集(superset)&a…

掌握现代CSS:变量、变形函数与动态计算

CSS近年来发展迅速,引入了许多强大的功能,如变量、高级变形函数和动态计算能力。本文将深入探讨如何在CSS中设置并使用变量,以及如何有效利用translate3d、translateY和translateX等变形方法。我们还将解析var()和calc()函数的关键作用。一、…

贝尔量子实验设想漏洞

1 0 1 0 1 1 0 1 0 1 1 1 0 0 1 0 带墨镜如果先上下交换再左右交换,很可能不一样的概率是2%,但是因为交换诞生了一个与之前序列相同的所以不一样概率变成1%,我们在测的时候不能这么测啊,你得看序列完…

在 Android 库模块(AAR)中,BuildConfig 默认不会自动生成 VERSION_CODE 和 VERSION_NAME 字段

为什么AAR库模块的 BuildConfig 没有 versionCode 和 versionName? aar库模块的 BuildConfig 默认不包含版本信息 应用模块(com.android.application)会自动生成 versionCode 和 versionName 到 BuildConfig。但库模块(com.androi…

强化学习 (11)随机近似

计算均值的新方法有两种方法。第一种方法很直接,即收集所有样本后计算平均值;但这种方法的缺点是,若样本是在一段时间内逐个收集的,我们必须等到所有样本都收集完毕。第二种方法可避免此缺点,因为它以增量迭代的方式计…

PHP `implode` 深度解析:从基础到高阶实战指南

文章目录一、基础语法与底层原理执行过程解析:二、性能关键:避免隐含陷阱1. 类型转换黑盒2. 大数组内存优化3. 关联数组处理三、高阶应用场景1. SQL语句安全构建2. CSV文件生成3. 模板引擎实现四、多维数组处理方案1. 递归降维2. JSON转换桥接五、性能对…

开发语言中关于面向对象和面向过程的笔记

开发语言中关于面向对象和面向过程的笔记市面主流语言分类面向过程面向对象市面主流语言分类 面向过程编程(Procedural Programming):C语言;面向对象编程语言(Object-Oriented Programming, OOP) &#xf…

AI产品经理面试宝典第3天:技术分层、边界与市场全景系列面试题

面试指导 面试官:请从技术实现效果的角度,解释AI技术分层。 你的回答: AI技术分为三层。 第一层是认知层:通过图像处理、语音识别、自然语言理解等技术,让机器感知环境。比如摄像头识别行人动作,麦克风捕捉用户指令。 第二层是预测层:基于行为数据预判下一步需求。例如…

Intel英特尔ICH7R/ICH8R/ICH9R/ICH10R系列下载地址--intel_msm_8961002 下载 Version 8.9.6.1002

Intel英特尔ICH7R/ICH8R/ICH9R/ICH10R系列下载地址intel_msm_8961002 下载 Version 8.9.6.1002https://xiazai.zol.com.cn/detail/66/653449.shtml通过网盘分享的文件:intel_msm_8961002.zip 链接: https://pan.baidu.com/s/13N9ZLXWkaWaEHQ5P90Jt0g?pwd3790 提取码…

AI(学习笔记第五课) 使用langchain进行AI开发 load documents(web)

文章目录AI(学习笔记第五课) 使用langchain进行AI开发 load documents(web)学习内容:1.load documents(web)1.1 学习url1.2 提前安装python的package1.2 使用WebBaseLoader进行webpage的load1.3 使用BeautifulSoup4进行webpage的部分截取1.4 …

使用macvlan实现容器的跨主机通信

使用环境: 两台运行docker的服务器 A机器网段:192.168.86.61 B机器网段:192.168.86.62 运行的容器需装有ping指令, 实验参数解释: -d macvlan 指定创建网络驱动类型 --subnet 指定子网范围 -gateway 指定网关地址 -o p…

深度学习_全连接神经网络

1.什么是神经网络神经网络中信息只向一个方向移动,即从输入节点向前移动,通过隐藏节点,再向输出节点移 动,网络中没有循环或者环。其中的基本构件是: 输入层:即输入x的那一层 输出层:即输出y的那…

OpenLayers使用

初学ol,实现了高德地图不同图层的切换、交互性地图飞行以及加载本地JSON数据。说一下不同图层切换的想法:1.对于标准地图和卫星地图:二者最初便挂载到map上,两个图层是叠加显示的;当点击按钮时,其实是使用 …

day4--上传图片、视频

1. 分布式文件系统 1.1 什么是分布式文件系统 文件系统是负责管理和存储文件的系统软件,操作系统通过文件系统提供的接口去存取文件,用户通过操作系统访问磁盘上的文件。 下图指示了文件系统所处的位置: 常见的文件系统:FAT16/FA…

极矢量与轴矢量

物理量分为标量和矢量,矢量又分为极矢量和轴矢量。 矢量是既有大小又有方向并按平行四边形法则相加的量。矢量有极矢量和轴矢量两种,其间的区别是在镜像反射变换下遵循不同的变换规律,许多物理量都是矢量,同样,其中也有极矢量和轴矢量的区分,在力学中,例…

文章发布易优CMS(Eyoucms)网站技巧

为了更快的上手数据采集及发布到易优CMS(eyoucms)网站,特地总结了些新手常常会遇到的操作问题与技巧,如下: 免费易优CMS采集发布插件下载,兼容火车头、八爪鱼、简数采集等 目录 1. 发布到易优CMS指定栏目 2. 发布文章到易优CM…