php redis 搜索,PHP+Redis有序集合(zset)实现博客园阅读排行榜功能
許多網站都有排行榜的功能,比如球員人氣榜單、閱讀排行榜,對于一些小網站,通過查數據庫就能實現排行榜的功能,但是對于稍微有點用戶量而且還是實時排名的網站,使用一些關系型數據庫如(MySQL、Oracle)等來實現就有點力不從心了,而且對數據庫的壓力也很大,體驗也不好,更好的選擇是使用Redis就是來做排行榜功能,因為Redis提供的有序集合(zset)非常適合做實時排行榜這個業務。
示例:今天我們就來使用PHP+Redis的zset來實現博客園網站的閱讀排行榜功能,博客園的文章閱讀排行榜頁面如下
假設現在有8篇文章,文章ID分別是1101、1102、1103、1104、1105、1106、1107、1108,我們使用redis的有序集合(zset)的score作為閱讀次數來記錄每篇文章的閱讀量,view_nums作為記錄閱讀量的key
現在,文章ID為1101、1102、1103、1104、1105、1106、1107、1108的文章分別被讀者閱讀了12次、245次、6次、99次、1267次、23次,456次,9999次
我們使用PHP代碼來實現記錄閱讀次數,使用的是zIncrBy()方法
上面的這串代碼應該放到文章詳情頁接口里,正常來說每次點擊詳情頁score都應該加1,這里為了演示,一次就增加了很多數。
我們通過Redis Desktop Manager軟件來查看目前的閱讀量情況
可以發現在redis的view_nums有序集合中,已經按照score的大小默認升序排序了。
現在我們要寫一個閱讀量前五的文章列表,這里需要使用zRevRange()方法
通過打印的結果可以看到,輸出結果是以文章ID為key,值為閱讀量的一個數組,并且是按照閱讀量降序排序的。
拿到結果之后,我們就可以提取出文章ID,然后從數據庫中取出這個幾個文章的標題
這里寫的是偽代碼,具體留給你們自己實現吧
如果該文章對您有幫助,請您點擊推薦,感謝。
總結
以上是生活随笔為你收集整理的php redis 搜索,PHP+Redis有序集合(zset)实现博客园阅读排行榜功能的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 芯片双雄罕见会面:三星Intel密谋重要
- 下一篇: 荣耀赵明:海外市场未来3-5年内不存在天