RedisJSON 內存占用剖析與調優

一、基礎內存模型

  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…