您好,登錄后才能下訂單哦!
這篇文章主要講解了“Redis中怎么用setbit統計活躍用戶”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Redis中怎么用setbit統計活躍用戶”吧!
首先,我們來看一下需求:網站統計用戶登錄的次數,具體如下:
網站有1億個用戶,有經常登錄的,也有不經常登錄的
如何來記錄用戶的登錄信息
如何查詢活躍用戶:比如:一周內,登錄3次的
我們使用傳統的關系型數據庫(比如:Oracle)來存儲這樣的數據
每周產生7億條數據,對于任何一個關系型數據庫來說,都是非常不好維護的,對性能也會有很大的影響。
Redis支持對String類型的value進行基于二進制位的置位操作。通過將一個用戶的id對應value上的一位,通過對活躍用戶對應的位進行置位,就能夠用一個value記錄所有活躍用戶的信息。如下圖所未,下圖中的bitmap有9個位被置為1,表示這9個位上對應的用戶是今天的活躍用戶。其中第15位表示uid為15的用戶,第一位表示uid為0的用戶。(如果你的uid不是從1開始的,比如從100000開始,實際上你也可以相應的用uid減去初始值來表示其位數,比如1000000用戶對應到bitmap的第一位)
具體的代碼類似下面這樣:
redis.setbit(key, user_id, 1)
這樣一次記錄的復雜度是O(1),在Redis中速度非常快。
下面代碼是在Redis CLI中執行的Demo演示,比如:用戶ID為100的用戶在星期一登錄了網站,我們就通過setbit操作,把星期一對應的100位的值置為1,
127.0.0.1:6379> setbit monday 100 1(integer) 0
而我們通過每天換用一個不同的key來將每天的活躍用戶狀態記錄分開存。并且可以通過一些與或運算計算出N天活躍用戶,和連接N天活躍用戶這樣的統計數據。
如下圖,第一行表示星期一的活躍用戶情況,第二行表示周二的,以此類推。為樣我們通過對N天的活躍用戶記錄取并集操作,就能得出在N天內活躍過的用戶列表。
感謝各位的閱讀,以上就是“Redis中怎么用setbit統計活躍用戶”的內容了,經過本文的學習后,相信大家對Redis中怎么用setbit統計活躍用戶這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。