欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis中3種特殊的數(shù)據(jù)類(lèi)型(BitMap、Geo和HyperLogLog)

 更新時(shí)間:2018年03月13日 10:36:21   作者:Sun_翁航  
這篇文章主要給大家介紹了關(guān)于Redis中3種特殊的數(shù)據(jù)類(lèi)型(BitMap、GEOADD和GEODIST)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。

前言

Reids 在 Web 應(yīng)用的開(kāi)發(fā)中使用非常廣泛,幾乎所有的后端技術(shù)都會(huì)有涉及到 Redis 的使用。Redis 種除了常見(jiàn)的字符串 String、字典 Hash、列表 List、集合 Set、有序集合 SortedSet 等等之外,還有一些不常用的數(shù)據(jù)類(lèi)型,這里著重介紹三個(gè)。下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧。

BitMap

BitMap 就是通過(guò)一個(gè) bit 位來(lái)表示某個(gè)元素對(duì)應(yīng)的值或者狀態(tài), 其中的 key 就是對(duì)應(yīng)元素本身,實(shí)際上底層也是通過(guò)對(duì)字符串的操作來(lái)實(shí)現(xiàn)。Redis 從 2.2 版本之后新增了setbit, getbit, bitcount 等幾個(gè) bitmap 相關(guān)命令。雖然是新命令,但是本身都是對(duì)字符串的操作,我們先來(lái)看看語(yǔ)法:

SETBIT key offset value

其中 offset 必須是數(shù)字,value 只能是 0 或者 1,咋一看感覺(jué)沒(méi)啥用處,我們先來(lái)看看 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í)際開(kāi)發(fā)的運(yùn)用呢?這里舉一個(gè)例子:儲(chǔ)存用戶(hù)在線狀態(tài)。這里只需要一個(gè) key,然后把用戶(hù) 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è)功能可以將用戶(hù)給定的地理位置信息儲(chǔ)存起來(lái), 并對(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 這樣的命令可以在之后通過(guò)位置查詢(xún)?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)中, 與中心的距離不超過(guò)給定最大距離的所有位置元素。距離單位和上面的一致,其中后面的選項(xiàng):

WITHDIST: 在返回位置元素的同時(shí), 將位置元素與中心之間的距離也一并返回。距離的單位和用戶(hù)給定的范圍單位保持一致。
WITHCOORD: 將位置元素的經(jīng)度和維度也一并返回。
WITHHASH: 以 52 位有符號(hào)整數(shù)的形式, 返回位置元素經(jīng)過(guò)原始 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ù)、每日訪問(wèn) IP 數(shù)、頁(yè)面實(shí)時(shí)UV)、在線用戶(hù)數(shù)等。但是它也有局限性,就是只能統(tǒng)計(jì)數(shù)量,而沒(méi)辦法去知道具體的內(nèi)容是什么。

當(dāng)然用集合也可以解決這個(gè)問(wèn)題。但是一個(gè)大型的網(wǎng)站,每天 IP 比如有 100 萬(wàn),粗算一個(gè) IP 消耗 15 字節(jié),那么 100 萬(wàn)個(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 的可見(jiàn)集合的并集。合并得出的 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

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • redis中List列表常見(jiàn)命令及使用場(chǎng)景

    redis中List列表常見(jiàn)命令及使用場(chǎng)景

    這篇文章主要給大家介紹了關(guān)于redis中List列表常見(jiàn)命令及使用場(chǎng)景的相關(guān)資料,Redis列表是簡(jiǎn)單的字符串列表,按照插入順序排序,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-01-01
  • Redis 單機(jī)安裝和哨兵模式集群安裝的實(shí)現(xiàn)

    Redis 單機(jī)安裝和哨兵模式集群安裝的實(shí)現(xiàn)

    本文主要介紹了Redis 單機(jī)安裝和哨兵模式集群安裝的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Redis常用數(shù)據(jù)類(lèi)型命令實(shí)例匯總

    Redis常用數(shù)據(jù)類(lèi)型命令實(shí)例匯總

    這篇文章主要介紹了Redis常用數(shù)據(jù)類(lèi)型命令實(shí)例匯總,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • Redis 存取 JSON 數(shù)據(jù)示例操作

    Redis 存取 JSON 數(shù)據(jù)示例操作

    JSON 是我們常用的數(shù)據(jù)類(lèi)型,當(dāng)我們需要在Redis中保存json數(shù)據(jù)時(shí)是怎么存放的呢?一般是用String或者Hash,但還是不太方便,無(wú)法靈活的操作json 數(shù)據(jù),下面通過(guò)本文給大家介紹Redis存取JSON 數(shù)據(jù)示例操作,感興趣的的朋友一起看看吧
    2024-02-02
  • Redis 多規(guī)則限流和防重復(fù)提交方案實(shí)現(xiàn)小結(jié)

    Redis 多規(guī)則限流和防重復(fù)提交方案實(shí)現(xiàn)小結(jié)

    本文主要介紹了Redis 多規(guī)則限流和防重復(fù)提交方案實(shí)現(xiàn)小結(jié),包括使用String結(jié)構(gòu)和Zset結(jié)構(gòu)來(lái)記錄用戶(hù)IP的訪問(wèn)次數(shù),具有一定的參考價(jià)值,感興趣的可以了解一下
    2025-02-02
  • Redis中鍵和數(shù)據(jù)庫(kù)通用指令詳解

    Redis中鍵和數(shù)據(jù)庫(kù)通用指令詳解

    這篇文章主要為大家介紹了Redis中鍵和數(shù)據(jù)庫(kù)通用指令基本操作詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • Redis MGET命令深度解析

    Redis MGET命令深度解析

    Redis的MGET命令是一種高效的批量讀取操作,可以顯著提高讀取性能,減少網(wǎng)絡(luò)往返的次數(shù),本文從MGET命令的機(jī)制實(shí)現(xiàn)、底層原理、應(yīng)用場(chǎng)景及性能優(yōu)化等多個(gè)維度,深入解析Redis中的MGET命令的工作方式,并對(duì)它與其他批量操作命令的對(duì)比進(jìn)行了詳細(xì)介紹
    2024-09-09
  • Linux上安裝Redis詳細(xì)教程

    Linux上安裝Redis詳細(xì)教程

    這篇文章主要給大家詳細(xì)介紹了在Linux上安裝Redis詳細(xì)教程,文中有詳細(xì)的代碼示例和安裝步驟,對(duì)我們學(xué)習(xí)安裝redis有一定的幫助,需要的朋友可以參考下
    2023-07-07
  • 如何利用Redis分布式鎖實(shí)現(xiàn)控制并發(fā)操作

    如何利用Redis分布式鎖實(shí)現(xiàn)控制并發(fā)操作

    這篇文章主要介紹了如何利用Redis分布式鎖實(shí)現(xiàn)控制并發(fā)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-09-09
  • Redis集群Lettuce主從切換問(wèn)題解決方案

    Redis集群Lettuce主從切換問(wèn)題解決方案

    這篇文章主要為大家介紹了Redis集群Lettuce主從切換問(wèn)題解決方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07

最新評(píng)論