成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

今天我才知道Redis有7種數據類型...

原創
存儲 存儲軟件 開發工具 Redis
面試官:Redis 有哪幾種數據類型?存儲原理是什么?具體適應哪些應用場景?是否歷歷在目,這是 Redis 關于數據類型的面試 3 連問,是除“Redis 持續化”外的最常見 Redis 考題。

【51CTO.com原創稿件】面試官:Redis 有哪幾種數據類型?存儲原理是什么?具體適應哪些應用場景?是否歷歷在目,這是 Redis 關于數據類型的面試 3 連問,是除“Redis 持續化”外的最常見 Redis 考題。

[[387092]] 

圖片來自 Pexels

但是,無論面試官的提問、網上的答案,基本都是錯的!本文將依據源碼向讀者做剖析,深入淺出,過目不忘。

查谷歌眾說紛紜

說法一:5 種

Redis 支持 5 種數據類型:

  • String(字符串)
  • List(列表)
  • Set(集合)
  • Sorted Set(有序集合)
  • Hash(哈希)

這也是被行業普遍認可,最最常見的答案。至于這 5 種類型的詳解,網上已經鋪天蓋地,這里不打算重復探討,請讀者自行溫習。

說法二:6 種 

包含了“說法一”的 5 種,還包含了:HyperLogLog(基數)。

也就是:String(字符串)、List(列表)、Set(集合)、Sorted Set(有序集合)、Hash(哈希)、HyperLogLog(基數)共 6 種。

 

說法三:9 種

包含了“說法二”的 6 種,還包含了:Bitmap(位集合)、Geospatial(地理空間索引)、Streams(流信息)3 種。

也就是:String(字符串)、List(列表)、Set(集合)、Sorted Set(有序集合)、Hash(哈希)、HyperLogLog(基數)、Bitmap(位集合)、Geospatial(地理空間索引)、Streams(流信息)共 9 種。

還有一說,并未包含 Streams(流信息),但是包含了 BloomFilter(布隆過濾器),這個不重要,但都稱是 9 種,尚未見有 10 種的說法。

 

從官網找答案

英文官網:https://redis.io/,中文官網:http://www.redis.cn/,首頁如下:

請留意這一句: 

Redis provides data structures such as strings, hashes, lists, sets, sorted sets with range queries, bitmaps, hyperloglogs, geospatial indexes, and streams.

很明顯,官網提到 Redis 支持的數據類型一共有 9 種。跟上文的“說法三”基本一致。

另外值得注意的是,中文官網沒有提及 Stream,也就是漏了一句話。因為 Stream 是在 2018 年 10 月 5.0 版本引入,但是中文官網至今沒有更新,是個非常明顯的文案 Bug(不知道反饋被采納會不會有獎金)。

那么問題到此解決了?還沒有!問題才剛剛開始。

具體問題具體分析

“說法一:5 種” 為什么會被行業普遍認可

先來看看 Redis 的各種高級功能類型被引入的版本,如下表:

 

很明顯,原因是:這些功能都是后續版本陸續引入的,5 種數據類型乃最經典的 5 種類型,所以代代相傳,傳承已久。

再來看看 Redis 的各個大版本的發布時間,如下表:

 

也就是說,“5 種數據類型”的認知,業界持續已有 10 年之久,認知的錯誤也有 10 年之久。

“說法三:9 種” 是否正確

要回答這個問題,先了解 Redis 的數據類型如何查看,可通過 type KEY_NAME 命令。

另外,通過 object encoding KEY_NAME 命令可查具體的編碼結構,這里僅稍作提及,不在本文的討論范圍內。

①String

  1. localhost:6379> set str:hello world 
  2. OK 
  3. localhost:6379> get str:hello 
  4. "world" 
  5. localhost:6379> type str:hello 
  6. string 

②Bitmap

  1. localhost:6379> setbit str:a 1 1 
  2. (integer) 0 
  3. localhost:6379> setbit str:a 2 1 
  4. (integer) 0 
  5. localhost:6379> setbit str:a 7 1 
  6. (integer) 0 
  7. localhost:6379> get str:a 
  8. "a" 
  9. localhost:6379> type str:a 
  10. string 

很明顯,Bitmap 底層也是 String 實現,賦值的每一個 bit 均對應 ASCII 碼的二進制位。

③HyperLogLog

  1. 127.0.0.1:6379> PFADD hyperLogLog:db "redis" 
  2. (integer) 1 
  3. 127.0.0.1:6379> PFADD hyperLogLog:db "mongodb" 
  4. (integer) 1 
  5. 127.0.0.1:6379> PFADD hyperLogLog:db "mysql" 
  6. (integer) 1 
  7. 127.0.0.1:6379> PFCOUNT hyperLogLog:db 
  8. (integer) 3 
  9. 127.0.0.1:6379> get hyperLogLog:db 
  10. "HYLL\x01\x00\x00\x00\x02\x00\x00\x00\x00\x00\x00\x00H\x91\x80\\g\x84[\x03" 
  11. 127.0.0.1:6379> type hyperLogLog:db 
  12. string 

很明顯,HyperLogLog 底層也是 String 實現,與其說 HyperLogLog 是一種單獨的數據類型,倒不如說是對 String 數據類型做 API 封裝的應用程序。

④歸納

其他幾種高級功能類型的驗證方式同,這里不做贅述,留給讀者自行驗證。

這里歸納結論如下:

 

饒了一圈似乎又回到了起點,“說法一:5 種”其實并沒有錯?畢竟任何類型的底層都是基于 5 種之一實現的。接著往下說。

Talk is cheap, Show me the code.

能說算不上什么,有本事就把你的代碼給我看看。

[[387093]]

源碼文件列表 

如下圖:

 

t_(type) 開頭的,有且僅有 6 個,除了“5 種數據類型”外,還包含了:t_stream。

Stream 是 Redis 5.0 版本引入的一個新的數據類型,支持消費者組,借鑒 Kafka 設計的支持多播的可持久化消息隊列(支持 group,不支持 partition)。

我們做下驗證:

  1. localhost:6379[2]> XADD stream:info * name aku alias bumblebee age 35 address sz 
  2. "1615012000623-0" 
  3. localhost:6379[2]> type stream:info 
  4. stream 

沒有問題:6 種,讓我們重新梳理一下:

  • String(字符串)
  • List(列表)
  • Set(集合)
  • Sorted Set(有序集合)
  • Hash(哈希)
  • Streams(流信息)

源碼就是源碼,讓人豁然開朗,查谷歌眾說紛紜、千篇一律,確實都不對!

那么問題答案到此解決?還沒有。但現在已經不是剛剛開始了,只差最后一步。

源碼內容

不能徒有其表,只看源碼文件列表,不看源碼內容。

 

這是關于類型的枚舉定義,0 到 6,什么?OBJ_MODULE?這是什么鬼?

請留意這一句描述:

* The "module" object type is a special one that signals that the object

* is one directly managed by a Redis module.

尤其是 special 一詞,這是 special 的類型,其余 6 類都是非 special 類型。既然 special,為什么其枚舉值是 5 會夾在 hash 和 stream 的非 special 之間?

歷史原因,Redis 4.0 引入了模塊擴展功能,當時已經認為是最后一個類型。

但是 Redis 5.0 又引入了 Stream 數據結構,可能是覬覦 Kafka 的市場份額,說白跟 RocketMQ 一樣都是仿照 Kafka 去實現的。

言歸正傳,所以該枚舉值的定義是不是跟我們日常業務開發的場景似曾相識,因為狀態值編號已經被占了,那么新加的狀態值就只能往后面排,導致五花八門一點都不連續。沒錯,就這么接地氣。

那么,module 用在什么場景?有很多場景,舉個最常用的例子:Leaky Bucket(漏桶算法),也就是 Redis 4.0 引入的 redis-cell 模塊。

示例如下:

  1. > cl.throttle module:leaky 14 30 60 1 
  2. 1) (integer) 0          # 0 表示允許  1 表示拒絕 
  3. 2) (integer) 15         # 漏斗容量 capacity 
  4. 3) (integer) 14         # 漏斗剩余空間 left_quota 
  5. 4) (integer) -1         # 如果拒絕了,需要多長時間后再重試,單位秒 
  6. 5) (integer) 2          # 多長時間后,漏斗完全空出來,單位秒 

那么問題答案到此解決?是的,通過分析源碼終于有了結論。

結論

Q:Redis 有哪幾種數據類型?

A:Redis 6.0 最新版本有且僅有 7 種。

按源碼中枚舉值定義的順序,分別為:

  • String(字符串)
  • List(列表)
  • Set(集合)
  • Sorted Set(有序集合)
  • Hash(哈希)
  • Module(模塊)
  • Streams(流信息)

Q:高級功能類型,比如 HyperLogLog、Bitmap 等呢?

A:高級功能類型是對數據類型做 API 封裝的應用程序。

HyperLogLog、Bitmap、Bloom Filter 的底層都是 String 數據類型,Geospatial 的底層是 Sorted Set 數據類型,cl.throttle(Redis-Cell) 的底層是 Module 數據類型。均可通過 type KEY_NAME 命令逐一核對。

所以,當面試官下次問你“Redis 數據類型的面試 3 連問”時候,可以好好的懟回去了,讓面試官看到你的理解、你對底層邏輯的掌握比面試官本人更系統、更專業,給面試官帶來些許的驚喜,相信面試效果會完全不一樣。

萬一驚喜變成了驚嚇怎么辦?也許該團隊是個固執己見的守舊團隊,面試官的考題可能也只是來自照本宣科的題庫,那么你可以把你的簡歷慢慢合上,揮一揮衣袖不帶走一片云彩。

最后,Talk is cheap,Show me the code。實踐才是檢驗真理的唯一標準,共勉,請不要再錯下去了。

作者:大黃蜂

簡介:曾就職于華為、騰訊等大型互聯網公司,于 2018 年 5 月加盟獨角獸公司 akulaku 擔任技術管理職務,對分期、金融借貸等核心系統的架構設計具有豐富的實戰經驗。精通 Redis 和 JVM,非常重視底層原理,對高級用法、協議、源碼等具有深入的研究。并且,具有自己獨特的團隊管理理念,另辟蹊徑,專注研發質量和效率,為公司培養出多名青年高潛,并多次榮獲各類表彰。

編輯:陶家龍 

征稿:有投稿、尋求報道意向技術人請添加小編微信 gordonlonglong

【51CTO原創稿件,合作站點轉載請注明原文作者和出處為51CTO.com】

 

責任編輯:武曉燕 來源: 51CTO技術棧
相關推薦

2020-02-03 16:52:43

Redis數據結構知道

2021-03-03 00:01:30

Redis數據結雙向鏈表

2021-11-08 09:33:07

JS 字符串數據類型

2019-12-18 14:41:07

Redis數據結構

2021-04-16 07:28:39

UUIDjavaJava基礎

2010-05-26 17:05:48

MySQL數據類型

2014-04-25 09:38:08

大數據

2011-07-01 15:32:58

Qt 數據類型

2011-03-31 15:53:39

設計視圖Access

2023-04-27 08:40:55

Redis數據結構存儲

2020-12-01 11:50:49

數據庫Redis面試

2016-08-01 10:42:58

數據類型WebWordPress

2010-07-23 14:18:47

SQL Server數

2019-11-11 14:55:25

Redis數據類型命令

2019-09-27 10:53:28

RedisPythonJava

2019-11-12 08:53:32

PG數據數據庫

2024-08-02 13:10:25

2023-07-04 08:41:08

Redis數據類型

2025-01-13 06:10:00

2025-05-13 08:05:00

Redis數據類型數據庫
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91一区二区三区 | 日韩欧美二区 | 99视频在线免费观看 | 亚洲欧美一区二区三区在线 | 在线免费观看色 | 日日夜夜天天 | 亚洲精品电影网在线观看 | 日韩欧美视频 | 日韩精品免费播放 | 国产一区中文 | 毛片一级片 | 51ⅴ精品国产91久久久久久 | 色综合一区二区 | 老牛嫩草一区二区三区av | 国产欧美精品一区二区三区 | 伊人中文字幕 | 色就干 | 国产中文一区二区三区 | 天天射天天操天天干 | 特级丰满少妇一级aaaa爱毛片 | 精品一区二区三区在线观看 | 中文字幕1区 | 视频在线日韩 | 亚洲高清在线观看 | 精品一区二区三区四区 | 亚洲精品国产成人 | 久久久久久亚洲 | 精品视频国产 | 亚洲精美视频 | www.欧美.com| 免费在线观看av网址 | 国产精品久久久久久久粉嫩 | 91视频网 | 久久久久久久久久久久久9999 | 一区二区亚洲 | aaa天堂| 91亚洲视频在线 | 久久一日本道色综合久久 | 黑人性hd | 91不卡| 精品一区二区三区在线观看国产 |