這篇文章主要介紹“redis的Object結(jié)構(gòu)體怎么定義”的相關(guān)知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強(qiáng),希望這篇“redis的Object結(jié)構(gòu)體怎么定義”文章能幫助大家解決問題。
10年積累的成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先網(wǎng)站制作后付款的網(wǎng)站建設(shè)流程,更有華鎣免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
redis的性能高的原因之一是它每種數(shù)據(jù)結(jié)構(gòu)都是經(jīng)過專門設(shè)計的,并都有一種或多種數(shù)據(jù)結(jié)構(gòu)來支持,依賴這些靈活的數(shù)據(jù)結(jié)構(gòu),來提升讀取和寫入的性能。如果要了解redis的數(shù)據(jù)結(jié)構(gòu),可以從兩個不同的層面來討論它:
第一個層面,是從使用者的角度,這一層面也是Redis暴露給外部的調(diào)用接口,比如:string,list,hash,set,sorted set。
第二個層面,是從內(nèi)部實現(xiàn)的角度,屬于更底層的實現(xiàn),比如:dict,sds,ziplist,quicklist,skiplist,intset。
從Redis的使用者的角度來看,一個Redis節(jié)點包含多個database(非cluster模式下默認(rèn)是16個,cluster模式下只能是1個),而一個database維護(hù)了從key space到object space的映射關(guān)系。這個映射關(guān)系的key是string類型,而value可以是多種數(shù)據(jù)類型,比如:string, list, hash、set、sorted set等。我們可以看到,key的類型固定是string,而value可能的類型是多個。
而從Redis內(nèi)部實現(xiàn)的角度來看,database內(nèi)的這個映射關(guān)系是用一個dict來維護(hù)的。dict的key固定用一種數(shù)據(jù)結(jié)構(gòu)來表達(dá)就夠了,這就是動態(tài)字符串sds。而value則比較復(fù)雜,為了在同一個dict內(nèi)能夠存儲不同類型的value,這就需要一個通用的數(shù)據(jù)結(jié)構(gòu),這個通用的數(shù)據(jù)結(jié)構(gòu)就是robj,全名是redisObject。
舉個例子:
如果value是一個list,那么它的內(nèi)部存儲結(jié)構(gòu)是一個quicklist。
如果value是一個string,那么它的內(nèi)部存儲結(jié)構(gòu)一般情況下是一個sds。但如果string類型的value的值是一個數(shù)字,那么Redis內(nèi)部還會把它轉(zhuǎn)成long型來存儲,從而減小內(nèi)存使用。
所以,一個robj既能表示一個sds,也能表示一個quicklist,甚至還能表示一個long型。
redisObject的定義如下:
typedef struct redisObject { unsigned type:4; unsigned encoding:4; unsigned lru:LRU_BITS; /* lru time (relative to server.lruclock) */ int refcount; void *ptr;} robj;
一個robj包含如下5個字段:
type: 對象的數(shù)據(jù)類型。占4個bit??赡艿娜≈涤?種: OBJ_STRING, OBJ_LIST, OBJ_SET, OBJ_ZSET,
OBJ_HASH,分別對應(yīng)Redis對外暴露的5種數(shù)據(jù)結(jié)構(gòu)
encoding: 對象的內(nèi)部表示方式(也可以稱為編碼),占4個bit,可能的取值有10種。
lru: 做LRU替換算法用,占24個bit。
refcount: 引用計數(shù)。它允許robj對象在某些情況下被共享。
ptr: 數(shù)據(jù)指針。指向真正的數(shù)據(jù)。比如,一個代表string的robj,它的ptr可能指向一個sds結(jié)構(gòu);一個代表list的robj,它的ptr可能指向一個quicklist。
這里特別需要仔細(xì)察看的是encoding字段。對于同一個type,還可能對應(yīng)不同的encoding,這說明同樣的一個數(shù)據(jù)類型,可能存在不同的內(nèi)部表示方式。而不同的內(nèi)部表示,在內(nèi)存占用和查找性能上會有所不同。
當(dāng)type = OBJ_STRING的時候,表示這個robj存儲的是一個string,這時encoding可以是下面3種中的一種:
OBJ_ENCODING_RAW: string采用原生的表示方式,即用sds來表示。
OBJ_ENCODING_INT: string采用數(shù)字的表示方式,實際上是一個long型。
OBJ_ENCODING_EMBSTR: string采用一種特殊的嵌入式的sds來表示。
當(dāng)type = OBJ_HASH的時候,表示這個robj存儲的是一個hash,這時encoding可以是下面2種中的一種:
OBJ_ENCODING_HT: hash采用一個dict來表示。
OBJ_ENCODING_ZIPLIST: hash采用一個ziplist來表示。
encoding的十種取值如下:
OBJ_ENCODING_RAW: 最原生的表示方式。其實只有string類型才會用這個encoding值(表示成sds)。
OBJ_ENCODING_INT: 表示成數(shù)字。實際用long表示。
OBJ_ENCODING_HT: 表示成dict。
OBJ_ENCODING_ZIPMAP: 是個舊的表示方式,已不再用。在小于Redis 2.6的版本中才有。
OBJ_ENCODING_LINKEDLIST: 也是個舊的表示方式,已不再用。
OBJ_ENCODING_ZIPLIST:表示成ziplist。
OBJ_ENCODING_INTSET: 表示成intset。用于set數(shù)據(jù)結(jié)構(gòu)。
OBJ_ENCODING_SKIPLIST: 表示成skiplist。用于sorted set數(shù)據(jù)結(jié)構(gòu)。
OBJ_ENCODING_EMBSTR: 表示成一種特殊的嵌入式的sds。
OBJ_ENCODING_QUICKLIST: 表示成quicklist。用于list數(shù)據(jù)結(jié)構(gòu)。
redisObject的作用的作用如下:
redisObjec是聯(lián)結(jié)兩個層面的數(shù)據(jù)結(jié)構(gòu)的橋梁。
為多種數(shù)據(jù)類型提供一種統(tǒng)一的表示方式。
允許同一類型的數(shù)據(jù)采用不同的內(nèi)部表示,從而在某些情況下盡量節(jié)省內(nèi)存。
支持對象共享和引用計數(shù)。當(dāng)對象被共享的時候,只占用一份內(nèi)存拷貝,進(jìn)一步節(jié)省內(nèi)存。
關(guān)于“redis的Object結(jié)構(gòu)體怎么定義”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,小編每天都會為大家更新不同的知識點。