Redis有序集合

Redis有序集合的編碼可以是 ziplist 或者 skiplist

ziplist和skiplist編碼選擇的標(biāo)準(zhǔn)在于Redis里的元素的數(shù)量以及元素成員的長度攒砖。
當(dāng)滿足以下2個(gè)條件時(shí),元素會(huì)選擇ziplist編碼:
① 有序集合保存的元素?cái)?shù)量小于128個(gè)
② 有序集合保存的所有元素成員的長度小于64字節(jié)

當(dāng)條件不滿足的時(shí)候日裙,ziplist可以向skiplist轉(zhuǎn)換吹艇。

ziplist:
ziplist編碼的有序集合對(duì)象使用壓縮列表作為底層實(shí)現(xiàn)。每個(gè)集合使用2個(gè)緊挨在一起的壓縮列表節(jié)點(diǎn)來保存昂拂,第一個(gè)保存元素的成員受神,第二個(gè)保存元素的分值。壓縮列表內(nèi)的集合按分值從小到大排序格侯,分值較小的元素被放置在靠近表頭的位置联四,分值較大的元素在靠近表尾的位置醉拓。

skiplist:
skiplist編碼的有序集合對(duì)象使用 zset結(jié)構(gòu)作為底層實(shí)現(xiàn),zset結(jié)構(gòu)同時(shí)包含一個(gè)字典和一個(gè)跳躍表排吴。
zset結(jié)構(gòu)的zsl跳躍表按分值從小到大保存了所有集合元素屹堰,每個(gè)跳躍表都保存了一個(gè)集合元素:跳躍表節(jié)點(diǎn)的object屬性保存了元素的成員淑趾,而跳躍表節(jié)點(diǎn)的score屬性保存了元素的分值扣泊。
從了zsl, zset里還保存了一個(gè)從成員到分值的映射评矩。

為什么有序集合需要同時(shí)使用跳躍表和字典來實(shí)現(xiàn)?
跳躍表利于執(zhí)行范圍操作(跳躍表是排好序的)蔗喂,而字典有利于執(zhí)行分值查找操作。同時(shí)由于Redis里的跳躍表和字典元素很多都是用指針實(shí)現(xiàn)的乖阵,所以不會(huì)浪費(fèi)內(nèi)存。

壓縮列表和跳躍表之間的區(qū)別对蒲?
壓縮列表是Redis為了節(jié)約內(nèi)存而開發(fā)的。是由一系列特殊編碼的連續(xù)內(nèi)存塊組成的順序型存儲(chǔ)結(jié)構(gòu)。當(dāng)一個(gè)列表鍵只包含少量列表項(xiàng)谈况,并且每個(gè)列表項(xiàng)要么是小整數(shù)值赡茸,要么是長度比較小的字符串占卧,Redis就會(huì)用壓縮列表作為其底層實(shí)現(xiàn)。
跳躍表是一種有序數(shù)據(jù)結(jié)構(gòu)叭喜。它通過在每個(gè)節(jié)點(diǎn)中維持多個(gè)指向其它節(jié)點(diǎn)的指針,從而達(dá)到快速訪問節(jié)點(diǎn)的目的啥辨。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末腊嗡,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子崇决,更是在濱河造成了極大的恐慌,老刑警劉巖盈厘,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件契吉,死亡現(xiàn)場離奇詭異菲语,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門澈吨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谅辣,“玉大人,你說我怎么就攤上這事◎悸迹” “怎么了荔泳?”我有些...
    開封第一講書人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵玛歌,是天一觀的道長擎椰。 經(jīng)常有香客問我译荞,道長圈膏,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任尿褪,我火速辦了婚禮,結(jié)果婚禮上杖玲,老公的妹妹穿的比我還像新娘摆马。我一直安慰自己囤采,他們只是感情好代虾,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開白布含蓉。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪见秽。 梳的紋絲不亂的頭發(fā)上步责,一...
    開封第一講書人閱讀 51,727評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音肮蛹,去河邊找鬼勺择。 笑死,一個(gè)胖子當(dāng)著我的面吹牛伦忠,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播稿辙,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼昆码,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了邻储?” 一聲冷哼從身側(cè)響起赋咽,我...
    開封第一講書人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎吨娜,沒想到半個(gè)月后脓匿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡宦赠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年陪毡,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片勾扭。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡毡琉,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出妙色,到底是詐尸還是另有隱情桅滋,我是刑警寧澤,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布身辨,位于F島的核電站丐谋,受9級(jí)特大地震影響芍碧,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜号俐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一泌豆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧萧落,春花似錦践美、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至许布,卻和暖如春兴革,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蜜唾。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來泰國打工杂曲, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人袁余。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓擎勘,卻偏偏與公主長得像,于是被迫代替她去往敵國和親颖榜。 傳聞我的和親對(duì)象是個(gè)殘疾皇子棚饵,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 本文為筆者對(duì)在學(xué)習(xí)Redis過程中所收集資料的一個(gè)總結(jié),目的是為了以后方便回顧相關(guān)的知識(shí),大部分為非原創(chuàng)內(nèi)容掩完。特此...
    EakonZhao閱讀 14,441評(píng)論 0 9
  • 參考來源 Redis的內(nèi)存優(yōu)化 Redis所有的數(shù)據(jù)都在內(nèi)存中噪漾,而內(nèi)存又是非常寶貴的資源。對(duì)于如何優(yōu)化內(nèi)存使用一直...
    秦漢郵俠閱讀 1,290評(píng)論 0 2
  • Redis為什么用跳表而不用平衡樹? 本文是《Redis內(nèi)部數(shù)據(jù)結(jié)構(gòu)詳解》系列的第六篇恶阴。在本文中诈胜,我們圍繞一個(gè)Re...
    meng_philip123閱讀 3,986評(píng)論 0 26
  • Redis的內(nèi)存優(yōu)化 聲明:本文內(nèi)容來自《Redis開發(fā)與運(yùn)維》一書第八章,如轉(zhuǎn)載請(qǐng)聲明存淫。 Redis所有的數(shù)據(jù)都...
    meng_philip123閱讀 18,892評(píng)論 2 29
  • 古琴有四種傳統(tǒng)的演奏形式桅咆,即獨(dú)奏括授、琴簫合奏、琴歌伴奏及雅樂合奏。其中荚虚,琴簫合奏薛夜,是一種極為常見的演奏形式,琴聲...
    藝然堂閱讀 1,437評(píng)論 0 0