主頁(yè) > 知識(shí)庫(kù) > 了解redis中RDB結(jié)構(gòu)_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

了解redis中RDB結(jié)構(gòu)_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

熱門標(biāo)簽:竹間科技AI電銷機(jī)器人 地圖標(biāo)注如何即時(shí)生效 百度商家地圖標(biāo)注怎么做 最簡(jiǎn)單的百度地圖標(biāo)注 西藏教育智能外呼系統(tǒng)價(jià)格 地圖標(biāo)注費(fèi)用 玄武湖地圖標(biāo)注 太原營(yíng)銷外呼系統(tǒng) 小紅書怎么地圖標(biāo)注店

RDB文件是在redis的“快照”的模式下才會(huì)產(chǎn)生,那么如果我們理解了RDB文件的結(jié)構(gòu),是不是讓我們對(duì)“快照”模式能做到一個(gè)心中有數(shù)呢???

一、RDB結(jié)構(gòu)剖析

  首先呢,我們要對(duì)RDB文件有一個(gè)概念性的認(rèn)識(shí),比如下面畫的圖一樣:

從圖中,我們大概看到了RDB文件的一個(gè)簡(jiǎn)要的存儲(chǔ)模式,但為了更好的方便對(duì)照,我準(zhǔn)備save一個(gè)empty database,對(duì)比一下看看效果:

然后我們用winHex打開dump.rdb文件,看看它的16進(jìn)制。

好了,該打開的我都打開了,下面我們一一來比較一下。

1. Redis參數(shù): 可以看到在16進(jìn)制的前5個(gè)字節(jié)中,是“REDIS"五個(gè)大字母,這個(gè)的作用顯而易見,肯定就是判斷當(dāng)前的文件是否為“RDB文件“,這樣才方便用常量的時(shí)間來判別。。。

2. db_version: 在Redis字符之后,我們看到了占用4個(gè)字節(jié)的0006,這個(gè)就是RDB文件結(jié)構(gòu)圖中的 db_version。對(duì)吧,同樣也很簡(jiǎn)單,就是判斷當(dāng)前Redis的版本號(hào),對(duì)否???

3. database: 由于我演示的是一個(gè)empty database,自然沒有相應(yīng)的結(jié)構(gòu),等下我們?cè)俨迦胗涗?,再?duì)比一下。

4. EOF: 從winHex上面你是否看到了,它占用一個(gè)字節(jié)的空間,就是一個(gè)“y”上面加了兩點(diǎn),由于用unicode無法表示,所以出現(xiàn)了這么個(gè)亂碼,當(dāng)然16進(jìn)制可以標(biāo)識(shí),就是所謂的“FF”,看到了沒有??? 那么它的作用就是標(biāo)識(shí)database的結(jié)束。

5. checksum: 從名字上你就可以看得到,它就是一個(gè)校驗(yàn)和,原理當(dāng)然就是看文件是否損壞,或者是否被修改,這樣有點(diǎn)像現(xiàn)在的OAuth驗(yàn)證,對(duì)吧,它占用了8個(gè)字節(jié),也就是最后的:DC B3 43 F0 5A DC F2 56。。。

二、帶數(shù)據(jù)的RDB文件結(jié)構(gòu)演示

好了,上面我已經(jīng)演示了除Database之外的所有參數(shù),下面我們來set一個(gè)最簡(jiǎn)單的string類型,看看database結(jié)構(gòu)是否如圖所示。

用WinHex打開dump.rdb文件如下:

為了方便對(duì)照,我在圖中標(biāo)記了一下Database開始的位置,也就是十六進(jìn)制的 FE。。。

1. database [selectDB]: 可以看到,selectDB其實(shí)就是一個(gè)無法用unicode標(biāo)記出來的一個(gè)字節(jié),十六進(jìn)制就是FE,當(dāng)redis碰到這個(gè)字符的時(shí)候就知道自己該干嘛了。。。。要準(zhǔn)備執(zhí)行select命令了。。。

2. database[db_number]: 在FE之后,我們看到了十六進(jìn)制的 ”03“,也就是切換到第三個(gè)數(shù)據(jù)庫(kù)中,還記得嗎? 我之前在set數(shù)據(jù)的時(shí)候,曾今執(zhí)行過select 3,也就是將數(shù)據(jù)set到第3號(hào)數(shù)據(jù)庫(kù)中,如果你忘記了,沒關(guān)系,我用redis客戶端打開給你看~~

3. database[pairs][type]: 當(dāng)你知道select哪一號(hào)數(shù)據(jù)庫(kù)之后,接下來的操作就是怎么去分析key,value數(shù)據(jù)了,在key/value數(shù)據(jù)中,第一個(gè)就是type,其實(shí)這個(gè)type就是你的value的encoding類型,可以看到在winHex中表示的0,也就是以下的源碼:

4.database[pairs][key][len]: 在type之后,就是所謂的key,而key的組合模式是【len,value】,其中l(wèi)en就是key的長(zhǎng)度,你也可以看到,winHex中表示的是 “04”,也就是說name的長(zhǎng)度為4。對(duì)吧。。。

5.database[pairs][key][value] 同樣的道理,這里的模式也是【len,value】,前面為value的length,后面為value的具體值。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Redis 徹底禁用RDB持久化操作
  • 淺談Redis中的RDB快照
  • Redis 通過 RDB 方式進(jìn)行數(shù)據(jù)備份與還原的方法
  • Redis持久化RDB和AOF區(qū)別詳解
  • Redis打開rdb文件常用方法詳解
  • redis學(xué)習(xí)之RDB、AOF與復(fù)制時(shí)對(duì)過期鍵的處理教程
  • Redis兩種持久化方案RDB和AOF詳解
  • Redis RDB技術(shù)底層原理詳解

標(biāo)簽:林芝 揚(yáng)州 廣東 贛州 唐山 澳門 景德鎮(zhèn) 香港

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《了解redis中RDB結(jié)構(gòu)_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理》,本文關(guān)鍵詞  了解,redis,中,RDB,結(jié)構(gòu),動(dòng)力,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《了解redis中RDB結(jié)構(gòu)_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于了解redis中RDB結(jié)構(gòu)_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章