Redis中的bitmap詳解
1、什么是bitmap?
bitmap也叫位圖,也就是用一個(gè)bit位來表示一個(gè)東西的狀態(tài),我們都知道bit位是二進(jìn)制,所以只有兩種狀態(tài),0和1。
2、為什么要有bitmap?
bitmap的出現(xiàn)就是為了大數(shù)據(jù)量而來的,但是前提是統(tǒng)計(jì)的這個(gè)大數(shù)據(jù)量每個(gè)的狀態(tài)只能有兩種,因?yàn)槊恳粋€(gè)bit位只能表示兩種狀態(tài)。
下面我們直接以一個(gè)統(tǒng)計(jì)億級(jí)用戶活動(dòng)的狀態(tài)來說明吧。
3、案例說明
3.1、案例描述
如果有一個(gè)上億用戶的系統(tǒng),需要我們?nèi)ソy(tǒng)計(jì)每一天的用戶登錄情況,我們應(yīng)該如何去解決?
前提條件:設(shè)置在9月19號(hào)有下標(biāo)為100、101、102、103四個(gè)用戶都登錄了系統(tǒng)
設(shè)置在9月20號(hào)有下標(biāo)為100、101、102三個(gè)用戶都登錄了系統(tǒng)
提出問題:
1、取出9月19號(hào)登錄系統(tǒng)的有多少人?
答:直接獲取即可。
2、取出9月19號(hào)和9月20號(hào)連續(xù)登錄系統(tǒng)的有多少人?
答:兩天的數(shù)據(jù)取&運(yùn)算。
3、取出9月19號(hào)與9月20號(hào)任意一天登錄的有多少人?
答:兩天的數(shù)據(jù)取|運(yùn)算。
3.2、解決方案
3.2.1、解決方案1—使用傳統(tǒng)數(shù)據(jù)庫(kù)解決
如果我們需要使用傳統(tǒng)的數(shù)據(jù)庫(kù)去統(tǒng)計(jì)的話,我么需要?jiǎng)?chuàng)建一張表,然后某個(gè)用戶登錄了,我們就去在表里面插上一條記錄,登記用戶的id,用戶登錄的時(shí)間等等,但是這樣出現(xiàn)的問題就是,每一天的數(shù)據(jù)量都很大,我們?cè)诮y(tǒng)計(jì)日活時(shí),效率就很低,所以這種解決方案是不能被考慮的。
3.2.2、解決方案2—使用bitmap解決
既然用戶登錄只有兩種狀態(tài),那么,我們就可以用bitmap
比如0表示未登錄,1表示登錄
// 設(shè)置在9月19號(hào)有下標(biāo)為100、101、102、103四個(gè)用戶都登錄了系統(tǒng) start 127.0.0.1:6379> setbit login_09_19 100 1 (integer) 0 127.0.0.1:6379> setbit login_09_19 101 1 (integer) 0 127.0.0.1:6379> setbit login_09_19 102 1 (integer) 0 127.0.0.1:6379> setbit login_09_19 103 1 (integer) 0 // 設(shè)置在9月19號(hào)有下標(biāo)為100、101、102、103四個(gè)用戶都登錄了系統(tǒng) end // 設(shè)置在9月20號(hào)有下標(biāo)為100、101、102三個(gè)用戶都登錄了系統(tǒng) start 127.0.0.1:6379> setbit login_09_20 100 1 (integer) 0 127.0.0.1:6379> setbit login_09_20 101 1 (integer) 0 127.0.0.1:6379> setbit login_09_20 102 1 (integer) 0 // 設(shè)置在9月20號(hào)有下標(biāo)為100、101、102三個(gè)用戶都登錄了系統(tǒng) end // 取出9月19號(hào)登錄系統(tǒng)的有多少人? start 127.0.0.1:6379> bitcount login_09_19 (integer) 4 // 取出9月19號(hào)登錄系統(tǒng)的有多少人? end // 取出9月19號(hào)和9月20號(hào)連續(xù)登錄系統(tǒng)的有多少人?start 127.0.0.1:6379> bitop and login_in_09_19_20:and login_09_19 login_09_20 (integer) 13 127.0.0.1:6379> bitcount login_in_09_19_20:and (integer) 3 // 取出9月19號(hào)和9月20號(hào)連續(xù)登錄系統(tǒng)的有多少人?end // 取出9月19號(hào)與9月20號(hào)任意一天登錄的有多少人?start 127.0.0.1:6379> bitop or login_in_09_19_20:or login_09_19 login_09_20 (integer) 13 127.0.0.1:6379> bitcount login_in_09_19_20:or (integer) 4 // 取出9月19號(hào)與9月20號(hào)任意一天登錄的有多少人?end

到此這篇關(guān)于Redis中的bitmap詳解的文章就介紹到這了,更多相關(guān)Redis中的bitmap內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Redis腦裂導(dǎo)致數(shù)據(jù)丟失的解決
本文主要介紹了Redis腦裂導(dǎo)致數(shù)據(jù)丟失的解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01
使用JMeter插件Redis Data Set如何實(shí)現(xiàn)高性能數(shù)據(jù)驅(qū)動(dòng)測(cè)試
RedisDataSet插件是JMeter的一個(gè)插件,可以實(shí)現(xiàn)從Redis中動(dòng)態(tài)加載數(shù)據(jù),并將其用作測(cè)試參數(shù),本文詳細(xì)介紹如何在JMeter中使用RedisDataSet插件,幫助你實(shí)現(xiàn)高效的數(shù)據(jù)驅(qū)動(dòng)測(cè)試2025-01-01
使用高斯Redis實(shí)現(xiàn)二級(jí)索引的方法
本文介紹了如何通過高斯Redis搭建二級(jí)索引,二級(jí)索引在電商、圖(hexastore)、游戲等領(lǐng)域具有廣泛的應(yīng)用場(chǎng)景,高斯redis現(xiàn)網(wǎng)亦有很多類似應(yīng)用,需要的朋友跟隨小編一起看看吧2022-07-07
Redis入門教程_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
Redis是一款開源的、高性能的鍵-值存儲(chǔ)(key-value store)。下面通過本文大家分享Redis入門教程,感興趣的朋友參考下吧2017-08-08
Redis 緩存實(shí)現(xiàn)存儲(chǔ)和讀取歷史搜索關(guān)鍵字的操作方法
這篇文章主要介紹了Redis 緩存實(shí)現(xiàn)存儲(chǔ)和讀取歷史搜索關(guān)鍵字,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12

