了解redis中RDB結(jié)構(gòu)_動力節(jié)點Java學(xué)院整理
RDB文件是在redis的“快照”的模式下才會產(chǎn)生,那么如果我們理解了RDB文件的結(jié)構(gòu),是不是讓我們對“快照”模式能做到一個心中有數(shù)呢???
一、RDB結(jié)構(gòu)剖析
首先呢,我們要對RDB文件有一個概念性的認(rèn)識,比如下面畫的圖一樣:
從圖中,我們大概看到了RDB文件的一個簡要的存儲模式,但為了更好的方便對照,我準(zhǔn)備save一個empty database,對比一下看看效果:
然后我們用winHex打開dump.rdb文件,看看它的16進(jìn)制。
好了,該打開的我都打開了,下面我們一一來比較一下。
1. Redis參數(shù): 可以看到在16進(jìn)制的前5個字節(jié)中,是“REDIS"五個大字母,這個的作用顯而易見,肯定就是判斷當(dāng)前的文件是否為“RDB文件“,這樣才方便用常量的時間來判別。。。
2. db_version: 在Redis字符之后,我們看到了占用4個字節(jié)的0006,這個就是RDB文件結(jié)構(gòu)圖中的 db_version。對吧,同樣也很簡單,就是判斷當(dāng)前Redis的版本號,對否???
3. database: 由于我演示的是一個empty database,自然沒有相應(yīng)的結(jié)構(gòu),等下我們再插入記錄,再對比一下。
4. EOF: 從winHex上面你是否看到了,它占用一個字節(jié)的空間,就是一個“y”上面加了兩點,由于用unicode無法表示,所以出現(xiàn)了這么個亂碼,當(dāng)然16進(jìn)制可以標(biāo)識,就是所謂的“FF”,看到了沒有??? 那么它的作用就是標(biāo)識database的結(jié)束。
5. checksum: 從名字上你就可以看得到,它就是一個校驗和,原理當(dāng)然就是看文件是否損壞,或者是否被修改,這樣有點像現(xiàn)在的OAuth驗證,對吧,它占用了8個字節(jié),也就是最后的:DC B3 43 F0 5A DC F2 56。。。
二、帶數(shù)據(jù)的RDB文件結(jié)構(gòu)演示
好了,上面我已經(jīng)演示了除Database之外的所有參數(shù),下面我們來set一個最簡單的string類型,看看database結(jié)構(gòu)是否如圖所示。
用WinHex打開dump.rdb文件如下:
為了方便對照,我在圖中標(biāo)記了一下Database開始的位置,也就是十六進(jìn)制的 FE。。。
1. database [selectDB]: 可以看到,selectDB其實就是一個無法用unicode標(biāo)記出來的一個字節(jié),十六進(jìn)制就是FE,當(dāng)redis碰到這個字符的時候就知道自己該干嘛了。。。。要準(zhǔn)備執(zhí)行select命令了。。。
2. database[db_number]: 在FE之后,我們看到了十六進(jìn)制的 ”03“,也就是切換到第三個數(shù)據(jù)庫中,還記得嗎? 我之前在set數(shù)據(jù)的時候,曾今執(zhí)行過select 3,也就是將數(shù)據(jù)set到第3號數(shù)據(jù)庫中,如果你忘記了,沒關(guān)系,我用redis客戶端打開給你看~~
3. database[pairs][type]: 當(dāng)你知道select哪一號數(shù)據(jù)庫之后,接下來的操作就是怎么去分析key,value數(shù)據(jù)了,在key/value數(shù)據(jù)中,第一個就是type,其實這個type就是你的value的encoding類型,可以看到在winHex中表示的0,也就是以下的源碼:
4.database[pairs][key][len]: 在type之后,就是所謂的key,而key的組合模式是【len,value】,其中l(wèi)en就是key的長度,你也可以看到,winHex中表示的是 “04”,也就是說name的長度為4。對吧。。。
5.database[pairs][key][value] 同樣的道理,這里的模式也是【len,value】,前面為value的length,后面為value的具體值。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
RabbitMQ+redis+Redisson分布式鎖+seata實現(xiàn)訂單服務(wù)的流程分析
訂單服務(wù)涉及許多方面,分布式事務(wù),分布式鎖,例如訂單超時未支付要取消訂單,訂單如何防止重復(fù)提交,如何防止超賣、這里都會使用到,這篇文章主要介紹了RabbitMQ+redis+Redisson分布式鎖+seata實現(xiàn)訂單服務(wù)的流程分析,需要的朋友可以參考下2024-07-07基于Redis6.2.6版本部署Redis?Cluster集群的問題
這篇文章主要介紹了基于Redis6.2.6版本部署Redis?Cluster集群,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-04-04SpringMVC集成redis配置的多種實現(xiàn)方法
這篇文章主要介紹了SpringMVC集成redis配置的多種實現(xiàn)方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03