這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)Redis中有哪些特殊的數(shù)據(jù)類型,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
成都創(chuàng)新互聯(lián)技術(shù)團(tuán)隊(duì)10年來致力于為客戶提供成都網(wǎng)站建設(shè)、做網(wǎng)站、高端網(wǎng)站設(shè)計(jì)、成都全網(wǎng)營(yíng)銷、搜索引擎SEO優(yōu)化等服務(wù)。經(jīng)過多年發(fā)展,公司擁有經(jīng)驗(yàn)豐富的技術(shù)團(tuán)隊(duì),先后服務(wù)、推廣了千余家網(wǎng)站,包括各類中小企業(yè)、企事單位、高校等機(jī)構(gòu)單位。前言
Reids 在 Web 應(yīng)用的開發(fā)中使用非常廣泛,幾乎所有的后端技術(shù)都會(huì)有涉及到 Redis 的使用。Redis 種除了常見的字符串 String、字典 Hash、列表 List、集合 Set、有序集合 SortedSet 等等之外,還有一些不常用的數(shù)據(jù)類型,這里著重介紹三個(gè)。下面話不多說了,來一起看看詳細(xì)的介紹吧。
BitMap
BitMap 就是通過一個(gè) bit 位來表示某個(gè)元素對(duì)應(yīng)的值或者狀態(tài), 其中的 key 就是對(duì)應(yīng)元素本身,實(shí)際上底層也是通過對(duì)字符串的操作來實(shí)現(xiàn)。Redis 從 2.2 版本之后新增了setbit, getbit, bitcount 等幾個(gè) bitmap 相關(guān)命令。雖然是新命令,但是本身都是對(duì)字符串的操作,我們先來看看語法:
SETBIT key offset value
其中 offset 必須是數(shù)字,value 只能是 0 或者 1,咋一看感覺沒啥用處,我們先來看看 bitmap 的具體表示,當(dāng)我們使用命令 setbit key (0,2,5,9,12) 1后,它的具體表示為:
byte | bit0 | bit1 | bit2 | bit3 | bit4 | bit5 | bit6 | bit7 |
---|---|---|---|---|---|---|---|---|
byte0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 |
byte1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 |
可以看出 bit 的默認(rèn)值是 0,那么 BitMap 在實(shí)際開發(fā)的運(yùn)用呢?這里舉一個(gè)例子:儲(chǔ)存用戶在線狀態(tài)。這里只需要一個(gè) key,然后把用戶 ID 作為 offset,如果在線就設(shè)置為 1,不在線就設(shè)置為 0。實(shí)例代碼:
//設(shè)置在線狀態(tài) $redis->setBit('online', $uid, 1); //設(shè)置離線狀態(tài) $redis->setBit('online', $uid, 0); //獲取狀態(tài) $isOnline = $redis->getBit('online', $uid); //獲取在線人數(shù) $isOnline = $redis->bitCount('online');
Geo
Redis 的 GEO 特性在 Redis 3.2 版本中推出, 這個(gè)功能可以將用戶給定的地理位置信息儲(chǔ)存起來, 并對(duì)這些信息進(jìn)行操作。GEO 的數(shù)據(jù)結(jié)構(gòu)總共有六個(gè)命令:geoadd、geopos、geodist、georadius、georadiusbymember、gethash,這里著重講解幾個(gè)。
1.GEOADD
GEOADD key longitude latitude member [longitude latitude member ...]
將給定的空間元素(緯度、經(jīng)度、名字)添加到指定的鍵里面。 這些數(shù)據(jù)會(huì)以有序集合的形式被儲(chǔ)存在鍵里面, 從而使得像 GEORADIUS 和 GEORADIUSBYMEMBER 這樣的命令可以在之后通過位置查詢?nèi)〉眠@些元素。例子:
redis> GEOADD Sicily 13.361389 38.115556 "Palermo" 15.087269 37.502669 "Catania" (integer) 2
2.GEOPOS
GEOPOS key member [member ...]
從鍵里面返回所有給定位置元素的位置(經(jīng)度和緯度),例子:
redis> GEOPOS Sicily Palermo Catania NonExisting 1) 1) "13.361389338970184" 2) "38.115556395496299"
3.GEODIST
GEODIST key member1 member2 [unit]
返回兩個(gè)給定位置之間的距離。如果兩個(gè)位置之間的其中一個(gè)不存在, 那么命令返回空值。指定單位的參數(shù) unit 必須是以下單位的其中一個(gè):(默認(rèn)為m)
m 表示單位為米。
km 表示單位為千米。
mi 表示單位為英里。
ft 表示單位為英尺。
redis> GEODIST Sicily Palermo Catania "166274.15156960039"
4.GEORADIUS
GEORADIUS key longitude latitude radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [ASC|DESC] [COUNT count]
以給定的經(jīng)緯度為中心, 返回鍵包含的位置元素當(dāng)中, 與中心的距離不超過給定大距離的所有位置元素。距離單位和上面的一致,其中后面的選項(xiàng):
WITHDIST: 在返回位置元素的同時(shí), 將位置元素與中心之間的距離也一并返回。距離的單位和用戶給定的范圍單位保持一致。
WITHCOORD: 將位置元素的經(jīng)度和維度也一并返回。
WITHHASH: 以 52 位有符號(hào)整數(shù)的形式, 返回位置元素經(jīng)過原始 geohash 編碼的有序集合分值。這個(gè)選項(xiàng)主要用于底層應(yīng)用或者調(diào)試, 實(shí)際中的作用并不大。
redis> GEORADIUS Sicily 15 37 200 km WITHDIST 1) 1) "Palermo" 2) "190.4424" 2) 1) "Catania" 2) "56.4413"
HyperLogLog
Redis 的基數(shù)統(tǒng)計(jì),這個(gè)結(jié)構(gòu)可以非常省內(nèi)存的去統(tǒng)計(jì)各種計(jì)數(shù),比如注冊(cè) IP 數(shù)、每日訪問 IP 數(shù)、頁面實(shí)時(shí)UV)、在線用戶數(shù)等。但是它也有局限性,就是只能統(tǒng)計(jì)數(shù)量,而沒辦法去知道具體的內(nèi)容是什么。
當(dāng)然用集合也可以解決這個(gè)問題。但是一個(gè)大型的網(wǎng)站,每天 IP 比如有 100 萬,粗算一個(gè) IP 消耗 15 字節(jié),那么 100 萬個(gè) IP 就是 15M。而 HyperLogLog 在 Redis 中每個(gè)鍵占用的內(nèi)容都是 12K,理論存儲(chǔ)近似接近 2^64 個(gè)值,不管存儲(chǔ)的內(nèi)容是什么,它一個(gè)基于基數(shù)估算的算法,只能比較準(zhǔn)確的估算出基數(shù),可以使用少量固定的內(nèi)存去存儲(chǔ)并識(shí)別集合中的唯一元素。而且這個(gè)估算的基數(shù)并不一定準(zhǔn)確,是一個(gè)帶有 0.81% 標(biāo)準(zhǔn)錯(cuò)誤的近似值。
這個(gè)數(shù)據(jù)結(jié)構(gòu)的命令有三個(gè):PFADD、PFCOUNT、PFMERGE
1.PFADD
redis> PFADD databases "Redis" "MongoDB" "MySQL" (integer) 1 redis> PFADD databases "Redis" # Redis 已經(jīng)存在,不必對(duì)估計(jì)數(shù)量進(jìn)行更新 (integer) 0
2.PFCOUNT
redis> PFCOUNT databases (integer) 3
3.PFMERGE
PFMERGE destkey sourcekey [sourcekey ...]
將多個(gè) HyperLogLog 合并為一個(gè) HyperLogLog, 合并后的 HyperLogLog 的基數(shù)接近于所有輸入 HyperLogLog 的可見集合的并集。合并得出的 HyperLogLog 會(huì)被儲(chǔ)存在 destkey 鍵里面, 如果該鍵并不存在,那么命令在執(zhí)行之前, 會(huì)先為該鍵創(chuàng)建一個(gè)空的 HyperLogLog 。
redis> PFADD nosql "Redis" "MongoDB" "Memcached" (integer) 1 redis> PFADD RDBMS "MySQL" "MSSQL" "PostgreSQL" (integer) 1 redis> PFMERGE databases nosql RDBMS OK redis> PFCOUNT databases (integer) 6
上述就是小編為大家分享的Redis中有哪些特殊的數(shù)據(jù)類型了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。