下面列出11種Web應(yīng)用場(chǎng)景波丰,在這些場(chǎng)景下可以充分的利用Redis的特性,大大提高效率午磁。
1.在主頁中顯示最新的項(xiàng)目列表
Redis使用的是常駐內(nèi)存的緩存,速度非痴泵牵快迅皇。LPUSH用來插入一個(gè)內(nèi)容ID,作為關(guān)鍵字存儲(chǔ)在列表頭部衙熔。LTRIM用來限制列表中的項(xiàng)目數(shù)最多為5000登颓。如果用戶需要的檢索的數(shù)據(jù)量超越這個(gè)緩存容量,這時(shí)才需要把請(qǐng)求發(fā)送到數(shù)據(jù)庫红氯。
2.刪除和過濾
如果一篇文章被刪除框咙,可以使用LREM從緩存中徹底清除掉咕痛。
3.排行榜及相關(guān)問題
排行榜(leader board)按照得分進(jìn)行排序。ZADD命令可以直接實(shí)現(xiàn)這個(gè)功能扁耐,而ZREVRANGE命令可以用來按照得分來獲取前100名的用戶暇检,ZRANK可以用來獲取用戶排名,非常直接而且操作容易婉称。
4.按照用戶投票和時(shí)間排序
這就像Reddit的排行榜块仆,得分會(huì)隨著時(shí)間變化。LPUSH和LTRIM命令結(jié)合運(yùn)用王暗,把文章添加到一個(gè)列表中悔据。一項(xiàng)后臺(tái)任務(wù)用來獲取列表,并重新計(jì)算列表的排序俗壹,ZADD命令用來按照新的順序填充生成列表科汗。列表可以實(shí)現(xiàn)非常快速的檢索绷雏,即使是負(fù)載很重的站點(diǎn)头滔。
5.過期項(xiàng)目處理
使用unix時(shí)間作為關(guān)鍵字,用來保持列表能夠按時(shí)間排序涎显。對(duì)current_time和time_to_live進(jìn)行檢索坤检,完成查找過期項(xiàng)目的艱巨任務(wù)。另一項(xiàng)后臺(tái)任務(wù)使用ZRANGE...WITHSCORES進(jìn)行查詢期吓,刪除過期的條目早歇。
6.計(jì)數(shù)
進(jìn)行各種數(shù)據(jù)統(tǒng)計(jì)的用途是非常廣泛的,比如想知道什么時(shí)候封鎖一個(gè)IP地址讨勤。INCRBY命令讓這些變得很容易箭跳,通過原子遞增保持計(jì)數(shù);GETSET用來重置計(jì)數(shù)器;過期屬性用來確認(rèn)一個(gè)關(guān)鍵字什么時(shí)候應(yīng)該刪除。
7.特定時(shí)間內(nèi)的特定項(xiàng)目
這是特定訪問者的問題潭千,可以通過給每次頁面瀏覽使用SADD命令來解決谱姓。SADD不會(huì)將已經(jīng)存在的成員添加到一個(gè)集合。
8.實(shí)時(shí)分析正在發(fā)生的情況刨晴,用于數(shù)據(jù)統(tǒng)計(jì)與防止垃圾郵件等
使用Redis原語命令屉来,更容易實(shí)施垃圾郵件過濾系統(tǒng)或其他實(shí)時(shí)跟蹤系統(tǒng)。
9.Pub/Sub
在更新中保持用戶對(duì)數(shù)據(jù)的映射是系統(tǒng)中的一個(gè)普遍任務(wù)割捅。Redis的pub/sub功能使用了SUBSCRIBE奶躯、UNSUBSCRIBE和PUBLISH命令,讓這個(gè)變得更加容易亿驾。
10.隊(duì)列
在當(dāng)前的編程中隊(duì)列隨處可見嘹黔。除了push和pop類型的命令之外,Redis還有阻塞隊(duì)列的命令,能夠讓一個(gè)程序在執(zhí)行時(shí)被另一個(gè)程序添加到隊(duì)列儡蔓。你也可以做些更有趣的事情郭蕉,比如一個(gè)旋轉(zhuǎn)更新的RSS feed隊(duì)列。
11.緩存
Redis緩存使用的方式與memcache相同喂江。
網(wǎng)絡(luò)應(yīng)用不能無休止地進(jìn)行模型的戰(zhàn)爭(zhēng)召锈,看看這些Redis的原語命令,盡管簡(jiǎn)單但功能強(qiáng)大获询,把它們加以組合涨岁,所能完成的就更無法想象。當(dāng)然吉嚣,你可以專門編寫代碼來完成所有這些操作梢薪,但Redis實(shí)現(xiàn)起來顯然更為輕松。