Redis位圖bitmap操作
定義
1、位圖不是真正的數(shù)據(jù)類型,它是定義在字符串類型中
2、一個(gè)字符串類型的值最多能存儲(chǔ)512M字節(jié)的內(nèi)容,位上限:2^32
# 1MB = 1024KB # 1KB = 1024Byte(字節(jié)) # 1Byte = 8bit(位)
強(qiáng)勢(shì)點(diǎn)
可以實(shí)時(shí)的進(jìn)行統(tǒng)計(jì),極其節(jié)省空間。官方在模擬1億2千8百萬用戶的模擬環(huán)境下,在一臺(tái)MacBookPro上,典型的統(tǒng)計(jì)如“日用戶數(shù)”的時(shí)間消耗小于50ms, 占用16MB內(nèi)存
SETBIT 命令
- 說明:設(shè)置某位置上的二進(jìn)制值
- 語法:SETBIT key offset value
- 參數(shù):offset - 偏移量 從0開始
? value - 0或者1
示例:
# 默認(rèn)擴(kuò)展位以0填充 127.0.0.1:6379> SET mykey ab OK 127.0.0.1:6379> GET mykey "ab" 127.0.0.1:6379> SETBIT mykey 0 1 (integer) 0 127.0.0.1:6379> GET mykey "\xe1b" 127.0.0.1:6379>
GETBIT 命令
- 說明:獲取某一位上的值
- 語法:GETBIT key offset
示例:
127.0.0.1:6379> GETBIT mykey 3 (integer) 0 127.0.0.1:6379> GETBIT mykey 0 (integer) 1 127.0.0.1:6379>
BITCOUNT 命令
- 說明:統(tǒng)計(jì)鍵所對(duì)應(yīng)的值中有多少個(gè) 1
- 語法:BITCOUNT key start end
- 參數(shù):start/end 代表的是 字節(jié)索引
示例:
127.0.0.1:6379> SET mykey1 ab OK 127.0.0.1:6379[4]> BITCOUNT mykey (integer) 6 127.0.0.1:6379[4]> BITCOUNT mykey 0 0 (integer) 3
應(yīng)用場(chǎng)景案例
# 網(wǎng)站用戶的上線次數(shù)統(tǒng)計(jì)(尋找活躍用戶)
用戶名為key,上線的天作為offset,上線設(shè)置為1
# 示例
用戶名為 user1:login 的用戶,今年第1天上線,第30天上線
SETBIT user1:login 0 1
SETBIT user1:login 29 1
BITCOUNT user1:login
到此這篇關(guān)于Redis位圖bitmap操作的文章就介紹到這了,更多相關(guān)Redis位圖操作內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Redis的Bitmap(位圖)詳解和命令演示
- PHP利用redis位圖實(shí)現(xiàn)簡(jiǎn)單的簽到功能
- Redis特殊數(shù)據(jù)類型bitmap位圖
- 淺談Redis位圖(Bitmap)及Redis二進(jìn)制中的問題
- 基于Redis位圖實(shí)現(xiàn)用戶簽到功能
- 基于Redis位圖實(shí)現(xiàn)系統(tǒng)用戶登錄統(tǒng)計(jì)
- PHP使用redis位圖bitMap 實(shí)現(xiàn)簽到功能
- Redis精確去重計(jì)數(shù)方法(咆哮位圖)
- redis通過位圖法記錄在線用戶的狀態(tài)詳解
- Redis 中的 BitMaps(位圖)命令詳解
相關(guān)文章
RedisDesktopManager?連接redis的方法
這篇文章主要介紹了RedisDesktopManager?連接redis,需要的朋友可以參考下2023-08-08
redis實(shí)現(xiàn)多級(jí)緩存同步方案詳解
這篇文章主要介紹了redis實(shí)現(xiàn)多級(jí)緩存同步方案詳解,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12
基于Redis實(shí)現(xiàn)分布式鎖以及任務(wù)隊(duì)列
這篇文章主要介紹了基于Redis實(shí)現(xiàn)分布式鎖以及任務(wù)隊(duì)列,需要的朋友可以參考下2015-11-11
內(nèi)存型數(shù)據(jù)庫(kù)Redis持久化小結(jié)
redis是一個(gè)支持持久化的內(nèi)存數(shù)據(jù)庫(kù),也就是說redis需要經(jīng)常將內(nèi)存中的數(shù)據(jù)同步到磁盤來保證持久化.redis支持四種持久化方式,一是 Snapshotting(快照)也是默認(rèn)方式,二是Append-only file(縮寫aof)的方式,三是虛擬內(nèi)存方式,四是diskstore方式.今天我們總結(jié)下前2種。2017-09-09
redis 實(shí)現(xiàn)登陸次數(shù)限制的思路詳解
這篇文章主要介紹了redis 實(shí)現(xiàn)登陸次數(shù)限制的思路詳解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08
Redis數(shù)據(jù)結(jié)構(gòu)之鏈表與字典的使用
這篇文章主要介紹了Redis數(shù)據(jù)結(jié)構(gòu)之鏈表與字典的使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05
詳解如何利用Redis實(shí)現(xiàn)生成唯一ID
隨著下單流量逐漸上升,為了降低數(shù)據(jù)庫(kù)的訪問壓力,需要通過請(qǐng)求唯一ID+redis分布式鎖來防止接口重復(fù)提交。今天我們就一起來看探討一下,如何通過服務(wù)端來完成請(qǐng)求唯一?ID?的生成2022-11-11

