《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 設計應用 > Redis ziplist內部結構分析
Redis ziplist內部結構分析
來源:nosqlfan
pesiwang
摘要: 本文來自對Redis內部ziplist結構的內部實現進行了詳細深入的分析,ziplist是用一個字符串來實現的雙向鏈表結構。
Abstract:
Key words :

ziplist是用一個字符串來實現的雙向鏈表結構,顧名思義,使用ziplist可以減少雙向鏈表的存儲空間,主要是節省了鏈表指針的存儲,如果存儲指向上一個鏈表結點和指向下一個鏈表結點的指針需要8個字節,而轉化成存儲上一個結點長度和當前結點長度在大多數情況下可以節省很多空間(最好的情況下只需2個字節)。但是每次向鏈表增加元素都需要重新分配內存。

ziplist中的結構體
typedef struct zlentry {
unsigned int prevrawlensize, prevrawlen;
unsigned int lensize, len;
unsigned int headersize;
unsigned char encoding;
unsigned char *p;
} zlentry;
Prevrawlen:上個鏈表結點占用的長度
Prevrawlensize:上個鏈表結點長度的存儲占用的字節數
Len:當前鏈表結點占用的長度
Lensize:當前鏈表結點長度的存儲占用的字節數
Headersize:當前鏈表結點的頭部大小, headersize = prevrawlensize + lensize
Encoding:當前鏈表結點長度(即字段len)使用的編碼類型
P:指向當前結點起始位置的指針
Ziplist的存儲結構
鏈表存儲結構
Zlbytes:一個4字節的無符號整型,存儲的是整個ziplist占用的字節數,用于重分配內存時使用。
Zltail:一個4字節的無符號整型,存儲的是鏈表最后一個結點的偏移值,即鏈表開頭地址+zltail即為最后一個結點的起始地址
Zllen:一個2字節的無符號整型,存儲的是鏈表中存儲的結點數,當這個值存儲的是2字節無符號整型的最大值時,需要遍歷鏈表獲取鏈表的結點數
Entry:鏈表結點,鏈表結點的存儲格式見結點存儲結構
Zlend:占用1字節的鏈表的結尾符,值為255
相關的宏定義
Ziplist.c: 89
/* Utility macros */
#define ZIPLIST_BYTES(zl) (*((uint32_t*)(zl)))
#define ZIPLIST_TAIL_OFFSET(zl) (*((uint32_t*)((zl)+sizeof(uint32_t))))
#define ZIPLIST_LENGTH(zl) (*((uint16_t*)((zl)+sizeof(uint32_t)*2)))
#define ZIPLIST_HEADER_SIZE (sizeof(uint32_t)*2+sizeof(uint16_t))
#define ZIPLIST_ENTRY_HEAD(zl) ((zl)+ZIPLIST_HEADER_SIZE)
#define ZIPLIST_ENTRY_TAIL(zl) ((zl)+ZIPLIST_TAIL_OFFSET(zl))
#define ZIPLIST_ENTRY_END(zl) ((zl)+ZIPLIST_BYTES(zl)-1)
結點存儲結構
<上一個鏈表結點占用的長度><當前鏈表結點占用的長度><當前結點數據>
上一個鏈表結點占用的長度
上一個鏈表結點占用的長度占用的字節數根據編碼類型而定
當長度數據小于254使用一個字節存儲,該字節存儲的數值就是該長度,
當長度數據大于等于254時,使用5個字節存儲,第一個字節的數值為254,表示接下來的4個字節才真正表示長度
當前鏈表結點用的長度存儲和數據存儲
第一個字節的前兩位用于區分長度存儲編碼類型和數據編碼類型,具體如下
字符串類型編碼
|00pppppp|
長度小于等于63(2^6-1)字節的字符串,后6位用于存儲字符串長度,長度與類型總共占用了1個字節
|01pppppp|qqqqqqqq|
長度小于等于16383(2^14-1)字節的字符串,后14位用于存儲字符串長度,長度與類型總共占用了2個字節
|10______|qqqqqqqq|rrrrrrrr|ssssssss|tttttttt|
長度大于等于16384字節的字符串,后4個字節用于存儲字符串長度,長度與類型總共占用了5個字節
整型編碼
|1100____|
整型類型,后2個字節存儲的值就是該整數
|1101____|
整型類型,后4個字節存儲的值就是該整數
|1110____|
整型類型,后8個字節存儲的值就是該整數
相關的宏定義
Ziplist.c:77
/* Different encoding/length possibilities */
#define ZIP_STR_06B (0 << 6)
#define ZIP_STR_14B (1 << 6)
#define ZIP_STR_32B (2 << 6)
#define ZIP_INT_16B (0xc0 | 0<<4)
#define ZIP_INT_32B (0xc0 | 1<<4)
#define ZIP_INT_64B (0xc0 | 2<<4)
/* Macro's to determine type */
#define ZIP_IS_STR(enc) (((enc) & 0xc0) < 0xc0)
#define ZIP_IS_INT(enc) (!ZIP_IS_STR(enc) && ((enc) & 0x30) < 0x30)
 
ziplist提供的接口
unsigned char *ziplistNew(void);
創建一個ziplist
返回創建的ziplist的指針
unsigned char *ziplistPush(unsigned char *zl, unsigned char *s, unsigned int slen, int where);
在ziplist的尾端或頭部添加一個結點
zl是ziplist的指針
s是待添加結點的值
slen是待添加結點的值長度
返回最新的ziplist的指針
unsigned char *ziplistIndex(unsigned char *zl, int index);
根據索引獲取ziplist的結點,封裝類似數組接口
zl是ziplist的指針
index是索引,從0開始,0即取鏈表的第一個結點,index可以是負數,負數表從后往前算,-1就是取鏈表的最后一個元素
如果index處有結點,則返回指向改結點的指針,否則返回NULL
unsigned char *ziplistNext(unsigned char *zl, unsigned char *p);
獲取ziplist的下一個結點
zl是無用參數
p是當前結點指針
如果還有下一個結點,則返回下一個結點的指針,否則返回NULL
unsigned char *ziplistPrev(unsigned char *zl, unsigned char *p);
獲取ziplist的上一個結點
zl是ziplist的指針
p是當前結點指針
如果還有上一個結點,則返回上一個結點的指針,否則返回NULL
unsigned int ziplistGet(unsigned char *p, unsigned char **sval, unsigned int *slen, long long *lval);
獲取p指向的當前結點的值
p是指向當前結點的指針
sval保存獲取到的當前結點的值的指針
slen是獲取到的當前結點的值的長度
lval是當值是整型時保存返回的數值
如果p指向的結點是合法結點返回1,否則返回0
unsigned char *ziplistInsert(unsigned char *zl, unsigned char *p, unsigned char *s, unsigned int slen);
在指針p指向的位置插入一個結點
zl是ziplist的指針
p是待插入結點的位置
s是待插入結點的值
slen是待插入結點的值的長度
返回最新的ziplist的指針
unsigned char *ziplistDelete(unsigned char *zl, unsigned char **p);
刪掉*p指向的結點
zl是ziplist的指針
p是一個value-result參數,傳入需刪除的結點,返回被刪除結點下一個結點的指針
返回最新的ziplist的指針
unsigned char *ziplistDeleteRange(unsigned char *zl, unsigned int index, unsigned int num);
刪除連續的一批結點
zl是ziplist的指針
index是開始刪除的索引
num是刪除的個數
返回最新的ziplist的指針
unsigned int ziplistCompare(unsigned char *p, unsigned char *s, unsigned int slen);
p指向的結點的值和s對應的值做比較
p是ziplist結點的指針
s是呆比較的值
slen是s的長度
相等返回1,否則返回0
unsigned int ziplistLen(unsigned char *zl);
取ziplist鏈表中元素的個數
zl是ziplist的指針
返回ziplist鏈表中元素的個數
size_t ziplistBlobLen(unsigned char *zl);
取ziplist鏈表占用的字節數
zl是ziplist的指針
返回ziplist鏈表占用的字節數
 
此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美老女人xx| 一区二区久久| 亚洲国产一区二区a毛片| 亚洲小说欧美另类社区| 亚洲精选一区二区| 亚洲高清视频一区二区| 国产一区二区欧美| 国产女主播视频一区二区| 国产精品成人va在线观看| 欧美日韩在线视频首页| 欧美老女人xx| 欧美日韩高清在线播放| 欧美精品亚洲| 欧美精品福利在线| 欧美大色视频| 欧美激情综合在线| 欧美精品一区三区在线观看| 老司机午夜精品视频| 久久亚洲不卡| 久久五月激情| 欧美精品午夜| 国产精品入口福利| 欧美午夜寂寞影院| 欧美日韩亚洲激情| 激情欧美亚洲| 国模一区二区三区| 国内成+人亚洲+欧美+综合在线| 国产女精品视频网站免费| 国产区在线观看成人精品| 国产视频自拍一区| 精品成人国产在线观看男人呻吟| 国产日本欧美视频| 韩日成人av| 亚洲影院色在线观看免费| 国产精品色午夜在线观看| 国产精品地址| 国产精品美女久久久久av超清 | 久久久久一区二区三区四区| 久久久精品一区| 欧美伊人久久大香线蕉综合69| 欧美一区二区三区四区高清 | 亚洲欧美日韩一区二区三区在线观看| 亚洲永久免费观看| 久久精彩视频| 欧美成人嫩草网站| 国产精品高潮呻吟| 国产美女精品视频| 在线成人激情视频| 99精品视频免费| 亚洲欧美日韩精品久久奇米色影视| 亚洲欧美日韩直播| 亚洲国产精品123| 日韩一区二区精品葵司在线| 亚洲欧美日韩国产一区二区三区| 亚洲丰满在线| 国产日韩欧美| 亚洲成人影音| 亚洲一区二区免费| 亚洲第一综合天堂另类专| 亚洲免费成人av电影| 亚洲欧美另类在线| 免费日韩精品中文字幕视频在线| 欧美日韩一二三区| 国产一区视频观看| 亚洲精品日韩精品| 欧美一区激情视频在线观看| 日韩天堂av| 久久精品成人一区二区三区蜜臀 | 午夜在线一区| 亚洲激情视频网| 午夜精品久久久久久久久久久久| 免费成人性网站| 欧美日本不卡高清| 国内精品视频一区| 99热精品在线| 亚洲国产精品久久久久秋霞蜜臀| 亚洲欧美日韩国产另类专区| 欧美99在线视频观看| 国产麻豆视频精品| 亚洲剧情一区二区| 亚洲国产高清自拍| 欧美在线视频一区二区| 欧美日韩成人在线观看| 激情成人亚洲| 亚洲性xxxx| 日韩一级在线观看| 久久综合色天天久久综合图片| 国产精品久久久久久久久久妞妞| 在线观看国产精品网站| 午夜精品三级视频福利| 一区二区欧美日韩视频| 你懂的国产精品| 国产午夜精品久久久| 在线亚洲免费视频| 99精品视频免费| 噜噜噜躁狠狠躁狠狠精品视频| 久久久999精品免费| 久久亚洲高清| 国产麻豆9l精品三级站| 亚洲美女在线观看| 最近中文字幕mv在线一区二区三区四区| 亚洲免费一在线| 欧美a级一区| 亚洲国产高清aⅴ视频| 99天天综合性| 久久一区二区三区超碰国产精品| 欧美午夜不卡在线观看免费| 亚洲福利视频二区| 久久国产色av| 亚洲另类黄色| 欧美在线一二三| 亚洲日本电影| 一级成人国产| 国产日韩一区二区三区在线播放| 亚洲人成在线影院| 午夜日韩激情| 亚洲欧美国产高清va在线播| 欧美日韩免费观看一区三区| 亚洲精品1区2区| 亚洲国产精品成人久久综合一区| 亚洲女人小视频在线观看| 亚洲一区日韩| 亚洲欧美国产高清va在线播| 欧美日精品一区视频| 久久国产加勒比精品无码| 久久成人综合网| 午夜激情亚洲| 欧美日韩一区免费| 日韩视频专区| 夜夜爽99久久国产综合精品女不卡| 久久精品亚洲精品| 日韩亚洲欧美在线观看| 久久久久久91香蕉国产| 久久在精品线影院精品国产| 久久琪琪电影院| 国产精品色婷婷| 亚洲黄网站黄| 亚洲一区高清| 亚洲精品影视在线观看| 国产精品日韩久久久| 一本色道综合亚洲| 国产精品久久久久久久午夜片| 亚洲色图制服丝袜| 国产视频一区二区三区在线观看| 国产精品卡一卡二卡三| 国产欧美日韩视频一区二区三区 | 你懂的网址国产 欧美| 亚洲高清视频一区| 亚洲视频一区二区在线观看 | 久久精品国产免费| 亚洲国产一区二区a毛片| 亚洲免费视频在线观看| 久久精品噜噜噜成人av农村| 欧美日韩国产精品| 亚洲午夜黄色| 欧美精品免费播放| 久久av在线看| 久久久久久尹人网香蕉| 亚洲欧美日韩精品久久亚洲区| 欧美一区二区免费视频| 久久久www免费人成黑人精品| 中文av一区特黄| 亚洲午夜高清视频| 午夜日韩视频| 国外成人网址| 日韩午夜三级在线| 国产精品乱码一区二三区小蝌蚪| 香蕉成人伊视频在线观看| 开心色5月久久精品| 亚洲久久一区二区| 欧美一二三区在线观看| 韩国在线视频一区| 一本久久a久久免费精品不卡| 国产精品视频区| 久久精品成人欧美大片古装| 欧美精品综合| 亚洲欧美日韩综合国产aⅴ| 欧美本精品男人aⅴ天堂| 日韩一级在线观看| 欧美制服丝袜第一页| 亚洲国产一区在线| 午夜视频久久久| 亚洲国产一区二区三区青草影视| 亚洲欧美日韩精品久久久久| 黄网站色欧美视频| 亚洲女人天堂av| 在线观看视频一区| 午夜精品一区二区三区电影天堂| 在线观看91精品国产入口| 亚洲一级在线观看| 精品成人在线视频| 午夜精品久久99蜜桃的功能介绍| 尤物网精品视频| 性欧美video另类hd性玩具| 亚洲国产高清aⅴ视频| 午夜视频一区| 亚洲激情电影中文字幕| 久久精品一本久久99精品| 一区二区三区欧美日韩| 欧美成人亚洲成人|