Redis中的bitmap詳解
1、什么是bitmap?
bitmap也叫位圖,也就是用一個bit位來表示一個東西的狀態(tài),我們都知道bit位是二進制,所以只有兩種狀態(tài),0和1。
2、為什么要有bitmap?
bitmap的出現就是為了大數據量而來的,但是前提是統(tǒng)計的這個大數據量每個的狀態(tài)只能有兩種,因為每一個bit位只能表示兩種狀態(tài)。
下面我們直接以一個統(tǒng)計億級用戶活動的狀態(tài)來說明吧。
3、案例說明
3.1、案例描述
如果有一個上億用戶的系統(tǒng),需要我們去統(tǒng)計每一天的用戶登錄情況,我們應該如何去解決?
前提條件:設置在9月19號有下標為100、101、102、103四個用戶都登錄了系統(tǒng)
設置在9月20號有下標為100、101、102三個用戶都登錄了系統(tǒng)
提出問題:
1、取出9月19號登錄系統(tǒng)的有多少人?
答:直接獲取即可。
2、取出9月19號和9月20號連續(xù)登錄系統(tǒng)的有多少人?
答:兩天的數據取&運算。
3、取出9月19號與9月20號任意一天登錄的有多少人?
答:兩天的數據取|運算。
3.2、解決方案
3.2.1、解決方案1—使用傳統(tǒng)數據庫解決
如果我們需要使用傳統(tǒng)的數據庫去統(tǒng)計的話,我么需要創(chuàng)建一張表,然后某個用戶登錄了,我們就去在表里面插上一條記錄,登記用戶的id,用戶登錄的時間等等,但是這樣出現的問題就是,每一天的數據量都很大,我們在統(tǒng)計日活時,效率就很低,所以這種解決方案是不能被考慮的。
3.2.2、解決方案2—使用bitmap解決
既然用戶登錄只有兩種狀態(tài),那么,我們就可以用bitmap
比如0表示未登錄,1表示登錄
// 設置在9月19號有下標為100、101、102、103四個用戶都登錄了系統(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 // 設置在9月19號有下標為100、101、102、103四個用戶都登錄了系統(tǒng) end // 設置在9月20號有下標為100、101、102三個用戶都登錄了系統(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 // 設置在9月20號有下標為100、101、102三個用戶都登錄了系統(tǒng) end // 取出9月19號登錄系統(tǒng)的有多少人? start 127.0.0.1:6379> bitcount login_09_19 (integer) 4 // 取出9月19號登錄系統(tǒng)的有多少人? end // 取出9月19號和9月20號連續(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號和9月20號連續(xù)登錄系統(tǒng)的有多少人?end // 取出9月19號與9月20號任意一天登錄的有多少人?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號與9月20號任意一天登錄的有多少人?end
到此這篇關于Redis中的bitmap詳解的文章就介紹到這了,更多相關Redis中的bitmap內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Redisson延時隊列RedissonDelayed的具體使用
定時調度基本是每個項目都會遇到的業(yè)務場景,一般地,都會通過任務調度工具執(zhí)行定時任務完成,但是會有一定的缺點,本文主要介紹了Redisson延時隊列RedissonDelayed的具體使用,感興趣的可以了解一下2024-02-02Redis出現(error)NOAUTH?Authentication?required.報錯的解決辦法(秒懂!)
這篇文章主要給大家介紹了關于Redis出現(error)NOAUTH?Authentication?required.報錯的解決辦法,對于 這個錯誤這通常是因為Redis服務器需要密碼進行身份驗證,但客戶端沒有提供正確的身份驗證信息導致的,需要的朋友可以參考下2024-03-03