主頁 > 資料庫 > Redis資料結構三之壓縮串列

Redis資料結構三之壓縮串列

2023-05-18 09:00:39 資料庫

本文首發于公眾號:Hunter后端
原文鏈接:Redis資料結構三之壓縮串列

本篇筆記介紹壓縮串列,

在 Redis 3.2 版本之前,壓縮串列是串列物件、哈希物件、有序集合物件的的底層實作之一,

因為壓縮串列本身結構上的一些缺陷,壓縮串列這個結構被替換了,但是壓縮串列結構本身有一些可取之處,并且替換它的新結構 listpack 與之很相似,所以我們這里還是介紹一下壓縮串列的結構和存盤

1、壓縮串列的結構

壓縮串列是 Redis 為了節約記憶體而開發的,由一個連續記憶體塊組成的順序型資料結構,

它的組成結構如下:

| zlbytes | zltail | zllen | entry1 | entry2 | ... | entryN | zlend |

壓縮串列的英文名是 ziplist,所以它的屬性都是 zl 開頭,

1. 串列屬性介紹

zlbytes

zlbytes 長度為 4 位元組,記錄整個壓縮串列占用的記憶體位元組數

zltail

zltail 長度為 4 位元組,記錄壓縮串列最后一個節點,也就是我們結構示例中的 entryN 到 zlbytes 的地址之間的偏移量,

zllen

zllen 長度為 2 位元組,記錄的是壓縮串列包含的節點數量,也就是結構中的 N,

zlend

zlend 長度為 1 位元組,它的值為 0xFF(十進制 255),用于標記壓縮串列的末端,

2. 壓縮串列節點屬性介紹

對于每一個 entry 節點,也就是壓縮串列中的元素節點,它的結構示意如下:

| previous_entry_length | encoding | content |

previous_entry_length

previous_entry_length 屬性記錄的是壓縮串列中前一個節點的長度

previous_entry_length 屬性本身的長度可以是 1 位元組或者 5 位元組

如果前一節點的長度小于 254 位元組,那么 previous_entry_length 屬性的長度為 1 位元組,前一個節點的長度保存在這個位元組里

如果前一節點的長度大于等于 254 位元組,那么 previous_entry_length 屬性的長度為 5 位元組,第一個位元組被設定成 0xFE(也就是 254),之后的四個位元組用于前一節點的長度,

通過 previous_entry_length 屬性,我們可以通過當前節點的地址和 previous_entry_length 屬性,計算出前一個節點的起始地址,壓縮串列的從表尾到表頭的遍歷操作就是使用這個原理一個節點一個節點往前回溯實作的,

encoding

encoding 屬性記錄了節點的 content 屬性所保存資料的型別以及長度,

encoding 的值如果是一位元組長,且值的最高位以 11 開頭,那么表示是整數編碼,表示 content 屬性保存著整數值,

encoding 的值為 一位元組、兩位元組、五位元組長,且值的最高位為 00、01、10 則表示是位元組陣列編碼

content

content 屬性保存的是節點的值,可以是一個位元組陣列或者整數,值的型別和長度由節點的 encoding 屬性決定,

2、 連鎖更新

在壓縮串列的節點屬性中,previous_entry_length 屬性的長度是根據前一節點的長度來進行賦值的,如果前一節點的長度小于 254 位元組,那么下一節點的 previous_entry_length 屬性長度為 1 位元組,如果前一節點的長度大于等于 254 位元組,那么下一節點的 previous_entry_length 屬性為 5 位元組,

那么在這種情況下,就存在一種較為極端的情況,那就是壓縮串列中每個節點的長度都在 250 - 253 位元組之間,這時候,如果在表頭插入一個長度大于等于 254 位元組的節點,那么相對應的第二個節點的 previous_entry_length 的長度就要從 1 位元組變為 4 位元組,那么該節點的整體長度就大于等于 254 位元組,

依此類推,壓縮串列的每一個節點的長度都會產生連鎖反應,長度都會逐個變成大于等于 254 位元組長度,程式就需要不斷地對壓縮串列執行空間重分配的操作,

Redis 將這種在特殊情況下產生的連續多次空間擴展操作稱為連鎖更新,

除了新增節點這種情況,還有一種洗掉節點也可能造成連鎖更新的情況,比如有這么幾個節點,big 節點的長度大于等于 254 位元組,small 節點長度小于254 位元組,e1 到 eN 的節點長度都在 250-253 位元組之間,

| zlbytes | zltail | zllen | big | small | entry1 | entry2 | ... | entryN | zlend |

這時候,洗掉 small 節點,entry1 節點的前節點的長度就會從 250-253 變成大于等于 254,因此 entry1 節點的 previous_entry_length 長度就會變成 5 位元組,entry1 整體長度就會大于等于 254 位元組,依次之后每個節點都會這樣產生連鎖更新,

盡管連鎖更新的復雜度較高,但它真正造成性能問題的幾率是很低的:

首先,壓縮串列里要恰好有多個連續的、長度介于 250-253 位元組之間的節點,連鎖反應才有可能被引發

其次,即使出現連鎖更新,但只要被更新的節點數量不多,就不會對性能造成任何影響,比如對只擁有三五個節點的壓縮串列進行連鎖更新,

3、壓縮串列缺點

壓縮串列雖然能節約記憶體,但仍然存在一些缺點:

  • 需要通過遍歷操作來查找節點,元素過多時會造成查詢效率低下
  • 對壓縮串列節點進行新增或者修改時,可能會造成連鎖更新的問題

如果想獲取更多后端相關文章,可掃碼關注閱讀:
image

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/552751.html

標籤:NoSQL

上一篇:多圖詳解:不停機分庫分表五個步驟

下一篇:返回列表

標籤雲
其他(159240) Python(38148) JavaScript(25433) Java(18055) C(15228) 區塊鏈(8267) C#(7972) AI(7469) 爪哇(7425) MySQL(7197) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5871) 数组(5741) R(5409) Linux(5340) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4572) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2433) ASP.NET(2403) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1975) 功能(1967) Web開發(1951) HtmlCss(1938) python-3.x(1918) C++(1917) 弹簧靴(1913) xml(1889) PostgreSQL(1878) .NETCore(1861) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • Redis資料結構三之壓縮串列

    本文首發于公眾號:Hunter后端 原文鏈接:Redis資料結構三之壓縮串列 本篇筆記介紹壓縮串列。 在 Redis 3.2 版本之前,壓縮串列是串列物件、哈希物件、有序集合物件的的底層實作之一。 因為壓縮串列本身結構上的一些缺陷,壓縮串列這個結構被替換了,但是壓縮串列結構本身有一些可取之處,并且替 ......

    uj5u.com 2023-05-18 09:00:39 more
  • 多圖詳解:不停機分庫分表五個步驟

    1 理論知識 1.1 分庫分表是否必要 分庫分表確實可以解決單表資料量大這個問題,但是并非首選。因為分庫分表至少引入了三個必須解決的突出問題。 第一是分庫分表方案本身具有的復雜性。第二是本地事務失效問題,原本在同一個資料庫中可以保證強一致性業務邏輯,分庫之后事務失效。第三是難以聚合查詢問題,因為分庫 ......

    uj5u.com 2023-05-18 09:00:25 more
  • 多表操作

    第一章 外鍵 在實際開發專案中,一個健壯的資料表一定有很好的參照完整性,為保證資料的完整性,需將兩表建立關系。這時可通過外鍵約束來實作 1.1、介紹 什么是外鍵約束? 在另一張表中參考另一張表的主鍵約束或唯一約束。 例如:如下操作創建表 create table grade( id int prim ......

    uj5u.com 2023-05-18 09:00:20 more
  • DQL陳述句(一) -----簡單select查詢

    DQL陳述句 1、格式 select 列名*N from 表名 where 查詢條件1 and/or 查詢條件2 group by 列 Having 分組條件 Order by 排序 2、規則 sql在書寫時除了查詢條件外,大小寫都可以 select * from user where uname=' ......

    uj5u.com 2023-05-18 08:55:07 more
  • [MySQL事務一文搞懂]

    [MySQL事務一文搞懂] 1、什么是事務? 事務(Transaction),顧名思義就是要做的或所做的事情,資料庫事務指的則是作為單個邏輯作業單元執行的一系列操作(SQL陳述句)。這些操作要么全部執行,要么全部不執行。 2、為什么需要事務 把一系列sql放入一個事務中有兩個目的: 為資料庫操作提供了 ......

    uj5u.com 2023-05-18 08:50:01 more
  • 玩轉MYSQL資料庫之--視圖詳解

    前言 從今天開始本系列文章就帶各位小伙伴學習資料庫技術。資料庫技術是Java開發中必不可少的一部分知識內容。也是非常重要的技術。本系列教程由淺入深, 全面講解資料庫體系。 非常適合零基礎的小伙伴來學習。 全文大約 【1297】字,不說廢話,只講可以讓你學到技術、明白原理的純干貨!本文帶有豐富案例及配 ......

    uj5u.com 2023-05-18 08:49:58 more
  • MySQL觸發器Trigger加載以及目前局限

    GreatSQL社區原創內容未經授權不得隨意使用,轉載請聯系小編并注明來源。 GreatSQL是MySQL的國產分支版本,使用上與MySQL一致。 作者: 亮 文章來源:GreatSQL社區原創 概念介紹 首先需要知道MySQL中觸發器特點,以及表table相關觸發器加載方式 MySQL中單個tri ......

    uj5u.com 2023-05-18 08:48:45 more
  • Greenplum資料庫中segment故障檢測

    1.Greenplum資料庫中segment故障檢測 1.1概述 Greenplum資料庫服務器(Postgres)有一個子行程,該子行程為ftsprobe,主要作用是處理故障檢測。 ftsprobe 監視Greenplum資料庫陣列,它以可以配置的間隔連接并掃描所有segment和資料庫行程。 如 ......

    uj5u.com 2023-05-18 08:48:31 more
  • 提高資料的安全性和可控性,數堆疊基于 Ranger 實作的 Spark SQL

    在企業級應用中,資料的安全性和隱私保護是極其重要的。Spark 作為數堆疊底層計算引擎之一,必須確保資料只能被授權的人員訪問,避免出現資料泄露和濫用的情況。為了實作Spark SQL 對資料的精細化管理及提高資料的安全性和可控性,數堆疊基于 Apache Ranger 實作了 Spark SQL 對資料 ......

    uj5u.com 2023-05-18 08:48:21 more
  • 單表查詢

    第一章 簡單查詢 1.1、select陳述句 mysql 中查詢資料的基本陳述句是select陳述句。 語法: select [distinct] 欄位1,欄位2,欄位3..... from 表名 [where 條件運算式] [group by 欄位名] [having 條件運算式] [order by ......

    uj5u.com 2023-05-16 22:26:48 more