關(guān)于統(tǒng)計在線人數(shù)囤采,第一反應(yīng)想到的是創(chuàng)建一個大型字典存儲用戶id與對應(yīng)的狀態(tài),但是這種方法耗費空間大,效率較低扎附。
通過學習 redis 想到更高效的方法抠忘。
原理:通過將用戶 id 作為位數(shù)撩炊,每次上線則將該位設(shè)為 1,下線則設(shè)為 0崎脉,通過 bitcount 來查詢有多少 1拧咳,通過 getbit,傳入用戶 id 來判斷當前用戶是否為上線狀態(tài)囚灼。
SET key value [EX seconds] [PX milliseconds] [NX|XX]
SETBIT key offset value
BITCOUNT key [start end] -> 返回的是二進制中 1 的個數(shù)
GETBIT key offset
如骆膝,一個id = 888888 的用戶上線了:
首先指定一個key:
set usercount 0
通過python 方法 ord('0') 得知字符 0 的 ASCII 碼值為 48
通過python 方法 bin(48) 得到二進制為 0110000
需要將所有位數(shù)設(shè)為0
setbit usercount 2 0
setbit usercount 3 0
直到 bitcount usercount 返回 0 為止祭衩,代表所有 usercount 的所有位數(shù)都為 0 了,這樣前置條件就完成了阅签。
id = 888888 的用戶上線
setbit usercount 888888 1 (這里當前usercount雖然沒有888888位掐暮,但只要通過setbit就可以創(chuàng)建)
id = 8889 的用戶上線
setbit usercount 8889 1
...
然后通過 bitcount usercount 判斷有多少1,則就知道有多少在線人數(shù)了政钟。(當前bitcount usercount 返回2路克,代表有2位用戶在線)
通過 getbit usercount 8889,來判斷用戶id = 8889 的用戶是否上線养交。
這樣即使網(wǎng)站有上億用戶精算,需要的存儲空間也只有10多M。
如果光想統(tǒng)計訪問人數(shù)层坠,則只需要
set count 0
incr count