亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Redis中怎么統計獨立用戶訪問量

發布時間:2021-07-26 15:43:17 來源:億速云 閱讀:460 作者:Leah 欄目:數據庫

Redis中怎么統計獨立用戶訪問量,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

使用Hash

哈希是Redis的一種基礎數據結構,Redis底層維護的是一個開散列,會把不同的key映射到哈希表上,如果是遇到關鍵字沖突,那么就會拉出一個鏈表出來。

當一個用戶訪問的時候,如果用戶登陸過,那么我們就使用用戶的id,如果用戶沒有登陸過,那么我們也能夠前端頁面隨機生成一個key用來標識用戶。

當用戶訪問的時候,我們可以使用HSET命令,key可以選擇URI與對應的日期進行拼湊,field可以使用用戶的id或者隨機標識,value可以簡單設置為1。

當我們要統計某一個網站某一天的訪問量的時候,就可以直接使用HLEN來得到最終的結果了。

Redis中怎么統計獨立用戶訪問量

優點:簡單,容易實現,查詢也是非常方便,數據準確性非常高。

缺點:占用內存過大,。隨著key的增多,性能也會下降。小網站還行,拼多多這種數億PV的網站肯定受不了。

使用Bitset

我們知道,對于一個32位的int,如果我們只用來記錄id,那么只能夠記錄一個用戶,但如果我們轉成2進制,每位用來表示一個用戶,那么我們就能夠一口氣表示32個用戶,空間節省了32倍!

對于有大量數據的場景,如果我們使用bitset,那么可以節省非常多的內存。

對于沒有登陸的用戶,我們也可以使用哈希算法,把對應的用戶標識哈希成一個數字id。bitset非常的節省內存,假設有1億個用戶,也只需要100000000/8/1024/1024約等于12兆內存。

Redis中怎么統計獨立用戶訪問量

Redis已經為我們提供了SETBIT的方法,使用起來非常的方便,我們可以看看下面的例子。

我們在item頁面可以不停地使用SETBIT命令,設置用戶已經訪問了該頁面,也可以使用GETBIT的方法查詢某個用戶是否訪問。最后我們通過BITCOUNT可以統計該網頁每天的訪問數量。

Redis中怎么統計獨立用戶訪問量

優點:占用內存更小,查詢方便,可以指定查詢某個用戶,數據可能略有瑕疵,對于非登陸的用戶,可能不同的key映射到同一個id,否則需要維護一個非登陸用戶的映射,有額外的開銷。

缺點:如果用戶非常的稀疏,那么占用的內存可能比方法一更大。

使用概率算法

對于拼多多這種多個頁面都可能非常多訪問量的網站,如果所需要的數量不用那么準確,可以使用概率算法。

事實上,我們對一個網站的UV的統計,1億跟1億零30萬其實是差不多的。

在Redis中,已經封裝了HyperLogLog算法,他是一種基數評估算法。這種算法的特征,一般都是數據不存具體的值,而是存用來計算概率的一些相關數據。

Redis中怎么統計獨立用戶訪問量

當用戶訪問網站的時候,我們可以使用PFADD命令,設置對應的命令,最后我們只要通過PFCOUNT就能順利計算出最終的結果,因為這個只是一個概率算法,所以可能存在0.81%的誤差。

優點:占用內存極小,對于一個key,只需要12kb。對于拼多多這種超多用戶的特別適用。

缺點:查詢指定用戶的時候,可能會出錯,畢竟存的不是具體的數據。總數也存在一定的誤差。

關于Redis中怎么統計獨立用戶訪問量問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

丽水市| 壶关县| 恩平市| 石棉县| 揭东县| 麻栗坡县| 靖远县| 青岛市| 图片| 东乡县| 页游| 封丘县| 西贡区| 鹿邑县| 普兰县| 昌图县| 金门县| 祁阳县| 尼勒克县| 霍山县| 景东| 准格尔旗| 仙桃市| 乐东| 环江| 明光市| 上犹县| 郴州市| 曲松县| 黄陵县| 封开县| 昌邑市| 宿迁市| 大同县| 砀山县| 黑龙江省| 吕梁市| 亚东县| 晋江市| 沙田区| 上犹县|