您好,登錄后才能下訂單哦!
Setbit 的實(shí)際應(yīng)用
場(chǎng)景: 1億個(gè)用戶, 每個(gè)用戶 登陸/做任意操作 ,記為 今天活躍,否則記為不活躍
每周評(píng)出: 有獎(jiǎng)活躍用戶: 連續(xù)7天活動(dòng)
每月評(píng),等等...
思路:
Userid dt active
1 2013-07-27 1
1 2013-0726 1
如果是放在表中, 1:表急劇增大,2:要用group ,sum運(yùn)算,計(jì)算較慢
用: 位圖法 bit-map
Log0721: ‘011001...............0’
......
log0726 : ‘011001...............0’
Log0727 : ‘0110000.............1’
1: 記錄用戶登陸:
每天按日期生成一個(gè)位圖, 用戶登陸后,把user_id位上的bit值置為1
2: 把1周的位圖 and 計(jì)算,
位上為1的,即是連續(xù)登陸的用戶
redis 127.0.0.1:6379> setbit mon 100000000 0 (一億用戶星期一的初始狀態(tài),都是0)
(integer) 0
redis 127.0.0.1:6379> setbit mon 3 1 (3號(hào)用戶周一登錄一次,計(jì)為1)
(integer) 0
redis 127.0.0.1:6379> setbit mon 5 1(5號(hào)用戶周一登錄一次,計(jì)為1)
(integer) 0
redis 127.0.0.1:6379> setbit mon 7 1(7號(hào)用戶周一登錄一次,計(jì)為1)
(integer) 0
redis 127.0.0.1:6379> setbit thur 100000000 0
(integer) 0
redis 127.0.0.1:6379> setbit thur 3 1
(integer) 0
redis 127.0.0.1:6379> setbit thur 5 1
(integer) 0
redis 127.0.0.1:6379> setbit thur 8 1
(integer) 0
redis 127.0.0.1:6379> setbit wen 100000000 0
(integer) 0
redis 127.0.0.1:6379> setbit wen 3 1
(integer) 0
redis 127.0.0.1:6379> setbit wen 4 1
(integer) 0
redis 127.0.0.1:6379> setbit wen 6 1
(integer) 0
redis 127.0.0.1:6379> bitop and res mon feb wen
(integer) 12500001
如上例,優(yōu)點(diǎn):
1: 節(jié)約空間, 1億人每天的登陸情況,用1億bit,約1200WByte,約10M 的字符就能表示
2: 計(jì)算方便
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。