Redis - 數據類型映射底層結構

簡介

從數據類型上體現就是,同一個數據類型,在不同的情況下會使用不同的編碼類型,底層所使用的的數據結構也不相同。

Redis 對象結構

字符串對象

字符串對象的編碼可以是?intraw?和?embstr?三者之一。

embstr?編碼是專門用于保存簡短字符串的一種優化編碼方式,與?raw?編碼會調用兩次內存分配函數分別創建?redisObject?結構和?sdshdr?結構不同,embstr?只會使用一次內存分配函數創建一塊連續的內存空間同時存放?redisObject?結構和?sdshdr?結構。

字符串轉換編碼的條件如下:

  • 如果字符串對象存儲的是整數值并且不超過?long?的范圍時,優先選擇使用?int?作為編碼方式
  • 如果存儲的字符串長度大于 32 個字節,會使用?raw?編碼的簡單動態字符串作為保存
  • 如果存儲的字符串長度小于 32 個字節,會使用?embstr?編碼的簡單動態字符串作為保存

字符串對象中有兩個需要注意的地方:

  • 對于存儲浮點數的字符串對象,實際上這個浮點數是以字符串值來保存的,執行如?INCRBYFLOAT?這樣的命令時,Redis 會先將字符串轉換成浮點數計算,然后再轉換成字符串值存儲
  • int?編碼和?embstr?編碼在條件滿足下會轉換成?raw?編碼。embstr?在執行修改命令之后總是會轉換成?raw?編碼,這個過程是不可逆的

列表對象

在 3.2 版本之前,列表對象的編碼可以是?ziplist?或者?zlinkedlist?的其中一個;在 3.2 版本之后,列表對象的編碼只能是?quicklist

哈希對象

哈希對象的編碼可以是?ziplist?或者?hashtable?中的一個。

哈希對象使用?ziplist?作為底層實現的時候,每當有新的鍵值對要插入哈希對象時,Redis 會先保存鍵的壓縮列表節點到壓縮列表的表尾,然后再保存值的壓縮列表節點到壓縮列表的表尾。

當哈希對象同時滿足以下兩個條件時,哈希對象使用?ziplist?編碼:

  • 哈希對象保存的所有鍵值對的鍵和值的字符串長度都小于 64 字節
  • 哈希對象保存的鍵值對數量小于 512 個

集合對象

集合對象的編碼可以是?intset?或者?hashtable?中的一個。

hashtable?編碼的集合對象使用字典作為底層實現,字典的每個鍵都是字符串對象,這個字符串對象包含著集合元素,字典的每個值都直接存儲?NULL

當集合對象同時滿足以下兩個條件時,集合對象使用?intset?編碼:

  • 集合對象保存的所有元素都是整數值
  • 集合對象保存的元素數據不超過 512 個

有序集合對象

有序集合對象的編碼可以是?ziplist?或者?skiplist?中的一個。

有序集合對象使用?ziplist?編碼作為底層實現時,每個集合對象會使用兩個緊挨在一起的壓縮列表節點來保存,第一個節點保存元素的成員,第二個元素則保存元素的分值。

這里有一點需要注意,skiplist?編碼的有序集合使用?zset?結構作為底層實現,一個?zset?結構包含一個字典和一個跳表。其中字典的鍵保存元素的成員,字典的值保存元素的分值;跳表的?object?屬性保存元素的成員,跳表的?score?屬性保存元素的分值。

理論上有序集合可以只使用字典或者跳表實現,但是使用兩個結構冗余存儲有序集合對象的成員和分值,既保留了字典?O(1)?時間復雜度查找的效率,也保留了跳表范圍型操作的所有優點。

當同時滿足以下兩個條件時,有序集合會使用?ziplist?編碼:

  • 有序集合保存的元素數量小于 128 個?
  • 有序集合保存的所有元素成員的長度都小于 64 字節

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/42343.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/42343.shtml
英文地址,請注明出處:http://en.pswp.cn/news/42343.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

每日一學——無線基礎知識

無線局域網(Wireless Local Area Network,簡稱 WLAN)是一種使用無線通信技術連接多個無線終端設備的局域網。它通常基于無線電波傳輸數據,并使用無線接入點(Access Point,簡稱 AP)來連接無線設備…

網絡安全--負載均衡

負載均衡 webshell實踐 一、負載均衡配置 1.在全局的http下寫下它: upstream nginx_boot{# 30s內檢查心跳發送兩次包,未回復就代表該機器宕機,請求分發權重比為1:2server 192.168.0.000:8080 weight100 max_fails2 fail_timeout30s; ser…

LeetCode150道面試經典題-- 合并兩個有序鏈表(簡單)

1.題目 將兩個升序鏈表合并為一個新的 升序 鏈表并返回。新鏈表是通過拼接給定的兩個鏈表的所有節點組成的。 2.示例 示例 1: 輸入:l1 [1,2,4], l2 [1,3,4] 輸出:[1,1,2,3,4,4] 示例 2: 輸入:l1 [], l2 [] 輸…

k8s 中快速啟動curl pod 做api test

場景 k8s上運行的pod需要進行api測試,由于開發使用的鏡像都是最小化構建,不能保證現有的pod中一定有curl工具,于是需要啟動一個帶有curl工具的測試pod專門進行api測試 指令 kubectl run curl-test-pod --imagecurlimages/curl -n {namespace} -i --tty -- sh上述指令實現在指…

“一日之際在于晨”,歡迎蒞臨WAVE SUMMIT上午場:Arm 虛擬硬件早餐交流會

8月16日,盛夏的北京將迎來第九屆WAVE SUMMIT深度學習開發者大會。在峰會主論壇正式開啟前,讓我們先用一份精美的元氣早餐,和一場“Arm虛擬硬件交流會”,喚醒各位開發小伙伴的開發魂! 8月16日,WAVE SUMMIT大…

時序預測 | MATLAB實現WOA-CNN-LSTM鯨魚算法優化卷積長短期記憶神經網絡時間序列預測

時序預測 | MATLAB實現WOA-CNN-LSTM鯨魚算法優化卷積長短期記憶神經網絡時間序列預測 目錄 時序預測 | MATLAB實現WOA-CNN-LSTM鯨魚算法優化卷積長短期記憶神經網絡時間序列預測預測效果基本介紹模型描述程序設計學習總結參考資料 預測效果 基本介紹 時序預測 | MATLAB實現WOA-…

華為OD真題--字符串中最小的整數和--帶答案

1. 華為OD機考題 答案 2023華為OD統一考試(AB卷)題庫清單-帶答案(持續更新) 2023年華為OD真題機考題庫大全-帶答案(持續更新) 2. 面試題 一手真實java面試題:2023年各大公司java面試真題匯總--…

java導入excel圖片處理

直接看代碼吧,主要邏輯吧excel的圖片拿到 壓縮上傳獲取url // 將文件轉成XSSFWorkbook工作簿XSSFWorkbook wb new XSSFWorkbook(uploadFile);// 獲取工作薄中第一個excel表格XSSFSheet sheet wb.getSheetAt(0);// 核心:::獲取ex…

R語言APSIM模型進階應用與參數優化、批量模擬實踐技術

隨著數字農業和智慧農業的發展,基于過程的農業生產系統模型在模擬作物對氣候變化的響應與適應、農田管理優化、作物品種和株型篩選、農田固碳和溫室氣體排放等領域扮演著越來越重要的作用。APSIM (Agricultural Production Systems sIMulator)模型是世界知名的作物生…

《論文閱讀14》FAST-LIO

一、論文 研究領域:激光雷達慣性測距框架論文:FAST-LIO: A Fast, Robust LiDAR-inertial Odometry Package by Tightly-Coupled Iterated Kalman Filter IEEE Robotics and Automation Letters, 2021 香港大學火星實驗室 論文鏈接論文github 二、論文概…

LeetCode49.字母異味詞分組

我一開始的思路就是用1個hashmap<Integer,List<String>>,Integer存的的是字符串所有字母ASCLL值的和&#xff0c;List里面放異位字符串&#xff0c;但是不是異位的字符串的ascll值也可能相同比如acd和abe&#xff0c;所以這個hashmap只能降低一點時間復雜度我還是要…

Vue--》打造個性化醫療服務的醫院預約系統(六)

今天開始使用 vue3 + ts 搭建一個醫院預約系統的前臺頁面,因為文章會將項目的每一個地方代碼的書寫都會講解到,所以本項目會分成好幾篇文章進行講解,我會在最后一篇文章中會將項目代碼開源到我的GithHub上,大家可以自行去進行下載運行,希望本文章對有幫助的朋友們能多多關…

Web APIs 第六天

正則表達式介紹語法元字符修飾符 一.正則表達式介紹 ① 簡介 用來匹配字符串中字符組合的模式在JavaScript中&#xff0c;正則表達式也是對象通常用來查找&#xff0c;替換那些符合正則表達式的文本&#xff0c;許多語言都支持正則表達式 ② 使用場景 驗證表單&#xff1a…

算法通關村第4關【白銀】| 棧的經典算法問題

1.括號匹配問題 思路&#xff1a;將左括號壓入棧中&#xff0c;遍歷字符串&#xff0c;當遇到右括號就出棧&#xff0c;判斷是否是匹配的一對&#xff0c;不是就返回false&#xff08;因為按照順序所以當遇到右括號出棧一定要是匹配的&#xff09;。使用Map來簡化ifelse clas…

編寫一套工具庫并上傳NPM

你的 工具箱 開箱即可用的 directive\utils&#xff0c; 說明&#xff1a;vue3-directive-tools 是一個方便在 Vue 3 Ts 項目中快速使用的 directive、tool 的 npm 插件。它允許您輕松地在項目中添加多種功能&#xff0c;它采用 Ts 方式開發&#xff0c;與 Vue3 更加搭配 npm&…

系統架構設計師---2017年上午試題1答案詳解

2017年上午試題1答案詳解 某計算機系統采用5級流水線結構執行指令,設每條指令的執行由取指令(2?t)、分析指令(1?t)、取操作數(3?t)、運算(1?t)和寫回結果(2?t)組成,并分別用5個子部完成,該流水線的最大吞吐率為(1);若連續向流水線輸入10條指令,則該流水線的加速比為(…

問道管理:放量打拐什么意思?常見的放量打拐三種形態?

成交量一直是股票交易中比較重要的目標&#xff0c;那么&#xff0c;放量打拐是什么意思&#xff1f;常見的放量打拐三種形狀是什么&#xff1f;下面問道管理為我們預備了相關內容&#xff0c;以供參閱。 放量打拐什么意思&#xff1f; 放量是指股票成交量與前幾個交易日比較顯…

安裝和配置 Ansible

安裝和配置 Ansible 按照下方所述&#xff0c;在控制節點 control.area12.example.com 上安裝和配置 Ansible&#xff1a; 安裝所需的軟件包 創建名為 /home/curtis/ansible/inventory 的靜態清單文件&#xff0c;以滿足以下要求&#xff1a; node1 是 dev 主機組的成員 node2 …

openGauss學習筆記-43 openGauss 高級數據管理-事件觸發器

文章目錄 openGauss學習筆記-43 openGauss 高級數據管理-事件觸發器43.1 語法格式43.2 參數說明43.3 示例 openGauss學習筆記-43 openGauss 高級數據管理-事件觸發器 觸發器會在指定的ddl事件發生時自動執行函數。目前事件觸發器僅在PG兼容模式下可用。 43.1 語法格式 創建事…

獨家!網絡機頂盒哪個好?測評員深度對比盤點網絡機頂盒排名

網絡機頂盒稱得上是家家戶戶必備&#xff0c;每年我都會進行網絡機頂盒的測評&#xff0c;今年已經測評過十幾款了&#xff0c;后臺收到很多私信不知道網絡機頂盒哪個好&#xff0c;我本期整理了網絡機頂盒排名&#xff0c;大家在選購時可以參考&#xff1a; ◆泰捷WEBOX 60Pro…