總體原則:key的名稱不易過長,剩下的所有 能用純數字表示的盡量用
Redis的每一個鍵值都是用一個redisObject結構體表示的
結構體中有:
?? ?鍵值的類型(string/list/hash/set/zset)
?? ?內部編碼方式(下面重點講)
?? ?該鍵值被多少次引用
?? ?內容指針
若內容指針指的是字符串,則內容指針指向sdshdr的結構體
?? ?(該結構體中 字符串長度、buf中剩余空間、buf字符數組[存字符串])
存儲鍵值空間 = redisObject大小 + sdshfr大小 + 字符串大小
若內容指針指的是數字,則內容指針直接就是數字
存儲鍵值空間 = redisObject大小
?
redis內部預先存有鍵值為0~9999的數字鍵值
字符串(編碼方式RAW、INT):
RAW redisObject內容指針指“純字符串”
INT redisObject內容指針指“數字”
散列表(兩種編碼方式 HT ZIPLIST)
配置文件 hash-max-ziplist-entries 512
?? ??? ? hash-max-ziplist-value 64
當鍵值的字段個數小于第一個值且字段名、字段值的字節數小于第二個值時用ZIPLIST
ZIPLIST:犧牲“讀性能”(O(n))換取極高的“空間利用率”,適合表在較小時使用
HT:字段名和字段值 都是 redisObject ;讀性能為O(1)
列表(編碼方式 LinkedList ziplist)
ziplist:同上
LinkedList:每個節點都是redisObject的雙向列表
集合(編碼方式 HT INTSET)
INTSET:集合中全是數字,且數字的個數小于指定值時使用
?? ??? ??? ?每個數字占位可變的動態數組
HT:字段值為nil,在集合縮小時,不會倒退到INSET
有序集合(編碼方式 SkipList ziplist)
ziplist:同上
SkipList:(由散列表和跳躍表組成)
?? ??? ?散列表存儲元素、分數映射
?? ??? ?跳躍表? 排序
?? ????
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
