Redis的一個(gè)非常大優(yōu)點(diǎn)就是能夠不用整個(gè)轉(zhuǎn)入到這個(gè)數(shù)據(jù)庫(kù),而是能夠沿用之前的MySQL等數(shù)據(jù)庫(kù),而僅在一些特定的應(yīng)用場(chǎng)景通過(guò)Redis的特性提高效率。本文列出了11個(gè)這種Web應(yīng)用場(chǎng)景,如顯示最新的項(xiàng)目列表、刪除和過(guò)濾、排行榜等相關(guān)需求。
【51CTO精選譯文】在 “怎樣讓Redis在你的系統(tǒng)中發(fā)揮作用”一文 中,Salvatore 'antirez’ Sanfilippo告訴我們?cè)鯓永肦edis獨(dú)有的數(shù)據(jù)結(jié)構(gòu)處理能力來(lái)解決一些常見(jiàn)問(wèn)題。一些Redis原語(yǔ)命令比方LPUSH、LTRIM和LREM等等可以用來(lái)幫助開(kāi)發(fā)人員完畢須要的任務(wù)——這些任務(wù)在傳統(tǒng)的數(shù)據(jù)庫(kù)存儲(chǔ)中很困難或緩慢。這是一篇很實(shí)用而且實(shí)際的文章。那么要怎樣在你的框架中完畢這些任務(wù)呢?
以下列出11種Web應(yīng)用場(chǎng)景,在這些場(chǎng)景下能夠充分的利用Redis的特性,大大提高效率。
1.在主頁(yè)中顯示最新的項(xiàng)目列表。
Redis使用的是常駐內(nèi)存的緩存,速度很快。LPUSH用來(lái)插入一個(gè)內(nèi)容ID,作為keyword存儲(chǔ)在列表頭部。LTRIM用來(lái)限制列表中的項(xiàng)目數(shù)最多為5000。假設(shè)用戶(hù)須要的檢索的數(shù)據(jù)量超越這個(gè)緩存容量,這時(shí)才須要把請(qǐng)求發(fā)送到數(shù)據(jù)庫(kù)。
2.刪除和過(guò)濾。
假設(shè)一篇文章被刪除,能夠使用LREM從緩存中徹底清除掉。?
3.排行榜及相關(guān)問(wèn)題。
排行榜(leader board)依照得分進(jìn)行排序。ZADD命令能夠直接實(shí)現(xiàn)這個(gè)功能,而ZREVRANGE命令能夠用來(lái)依照得分來(lái)獲取前100名的用戶(hù),ZRANK能夠用來(lái)獲取用戶(hù)排名,很直接并且操作easy。
4.依照用戶(hù)投票和時(shí)間排序。
這就像Reddit的排行榜,得分會(huì)隨著時(shí)間變化。LPUSH和LTRIM命令結(jié)合運(yùn)用,把文章加入到一個(gè)列表中。一項(xiàng)后臺(tái)任務(wù)用來(lái)獲取列表,并又一次計(jì)算列表的排序,ZADD命令用來(lái)依照新的順序填充生成列表。列表能夠?qū)崿F(xiàn)非常高速的檢索,即使是負(fù)載非常重的網(wǎng)站。
5.過(guò)期項(xiàng)目處理。
使用unix時(shí)間作為keyword,用來(lái)保持列表可以按時(shí)間排序。對(duì)current_time和time_to_live進(jìn)行檢索,完畢查找過(guò)期項(xiàng)目的艱巨任務(wù)。還有一項(xiàng)后臺(tái)任務(wù)使用ZRANGE...WITHSCORES進(jìn)行查詢(xún),刪除過(guò)期的條目。
6.計(jì)數(shù)。
進(jìn)行各種數(shù)據(jù)統(tǒng)計(jì)的用途是非常廣泛的,比方想知道什么時(shí)候封鎖一個(gè)IP地址。INCRBY命令讓這些變得非常easy,通過(guò)原子遞增保持計(jì)數(shù);GETSET用來(lái)重置計(jì)數(shù)器;過(guò)期屬性用來(lái)確認(rèn)一個(gè)keyword什么時(shí)候應(yīng)該刪除。
7.特定時(shí)間內(nèi)的特定項(xiàng)目。
這是特定訪問(wèn)者的問(wèn)題,能夠通過(guò)給每次頁(yè)面瀏覽使用SADD命令來(lái)解決。SADD不會(huì)將已經(jīng)存在的成員加入到一個(gè)集合。
8.實(shí)時(shí)分析正在發(fā)生的情況,用于數(shù)據(jù)統(tǒng)計(jì)與防止垃圾郵件等。
使用Redis原語(yǔ)命令,更easy實(shí)施垃圾郵件過(guò)濾系統(tǒng)或其它實(shí)時(shí)跟蹤系統(tǒng)。
9.Pub/Sub。
在更新中保持用戶(hù)對(duì)數(shù)據(jù)的映射是系統(tǒng)中的一個(gè)普遍任務(wù)。Redis的pub/sub功能使用了SUBSCRIBE、UNSUBSCRIBE和PUBLISH命令,讓這個(gè)變得更加easy。?
10.隊(duì)列。
在當(dāng)前的編程中隊(duì)列隨處可見(jiàn)。除了push和pop類(lèi)型的命令之外,Redis還有堵塞隊(duì)列的命令,可以讓一個(gè)程序在運(yùn)行時(shí)被還有一個(gè)程序加入到隊(duì)列。你也可以做些更有趣的事情,比方一個(gè)旋轉(zhuǎn)更新的RSS feed隊(duì)列。
11.緩存。
Redis緩存使用的方式與memcache同樣。
網(wǎng)絡(luò)應(yīng)用不能無(wú)休止地進(jìn)行模型的戰(zhàn)爭(zhēng),看看這些Redis的原語(yǔ)命令,雖然簡(jiǎn)單但功能強(qiáng)大,把它們加以組合,所能完畢的就更無(wú)法想象。當(dāng)然,你能夠?qū)iT(mén)編寫(xiě)代碼來(lái)完畢全部這些操作,但Redis實(shí)現(xiàn)起來(lái)顯然更為輕松。
原文: 11 Common Web Use Cases Solved In Redis
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元

