Redis能幹啥?細看11種Web應用場景

下面列出11種Web應用場景,在這些場景下可以充分的利用Redis的特性,大大提高效率。

1.在主頁中顯示最新的項目列表。

Redis使用的是常駐內存的緩存,速度非常快。LPUSH用來插入一個內容ID,作爲關鍵字存儲在列表頭部。LTRIM用來限制列表中的項目數最多爲5000。如果用戶需要的檢索的數據量超越這個緩存容量,這時才需要把請求發送到數據庫。

2.刪除和過濾。

如果一篇文章被刪除,可以使用LREM從緩存中徹底清除掉。 

3.排行榜及相關問題。

排行榜(leader board)按照得分進行排序。ZADD命令可以直接實現這個功能,而ZREVRANGE命令可以用來按照得分來獲取前100名的用戶,ZRANK可以用來獲取用戶排名,非常直接而且操作容易。

4.按照用戶投票和時間排序。

這就像Reddit的排行榜,得分會隨着時間變化。LPUSH和LTRIM命令結合運用,把文章添加到一個列表中。一項後臺任務用來獲取列表,並重新計算列表的排序,ZADD命令用來按照新的順序填充生成列表。列表可以實現非常快速的檢索,即使是負載很重的站點。

5.過期項目處理。

使用unix時間作爲關鍵字,用來保持列表能夠按時間排序。對current_time和time_to_live進行檢索,完成查找過期項目的艱鉅任務。另一項後臺任務使用ZRANGE...WITHSCORES進行查詢,刪除過期的條目。

6.計數。

進行各種數據統計的用途是非常廣泛的,比如想知道什麼時候封鎖一個IP地址。INCRBY命令讓這些變得很容易,通過原子遞增保持計數;GETSET用來重置計數器;過期屬性用來確認一個關鍵字什麼時候應該刪除。

7.特定時間內的特定項目。

這是特定訪問者的問題,可以通過給每次頁面瀏覽使用SADD命令來解決。SADD不會將已經存在的成員添加到一個集合。

8.實時分析正在發生的情況,用於數據統計與防止垃圾郵件等。

使用Redis原語命令,更容易實施垃圾郵件過濾系統或其他實時跟蹤系統。

9.Pub/Sub。

在更新中保持用戶對數據的映射是系統中的一個普遍任務。Redis的pub/sub功能使用了SUBSCRIBE、UNSUBSCRIBE和PUBLISH命令,讓這個變得更加容易。 

10.隊列。

在當前的編程中隊列隨處可見。除了push和pop類型的命令之外,Redis還有阻塞隊列的命令,能夠讓一個程序在執行時被另一個程序添加到隊列。你也可以做些更有趣的事情,比如一個旋轉更新的RSS feed隊列。

11.緩存。

Redis緩存使用的方式與memcache相同。

網絡應用不能無休止地進行模型的戰爭,看看這些Redis的原語命令,儘管簡單但功能強大,把它們加以組合,所能完成的就更無法想象。當然,你可以專門編寫代碼來完成所有這些操作,但Redis實現起來顯然更爲輕鬆。


毫無疑問,Redis開創了一種新的數據存儲思路,使用Redis,我們不用在面對功能單調的數據庫時,把精力放在如何把大象放進冰箱這樣的問題上,而是利用Redis靈活多變的數據結構和數據操作,爲不同的大象構建不同的冰箱。希望你喜歡這個比喻。

下面是一篇新鮮出爐的文章,其作者是Redis作者@antirez,他描述了Redis比較適合的一些應用場景,NoSQLFan簡單列舉在這裏,供大家一覽:

1.取最新N個數據的操作

比如典型的取你網站的最新文章,通過下面方式,我們可以將最新的5000條評論的ID放在Redis的List集合中,並將超出集合部分從數據庫獲取

  • 使用LPUSH latest.comments<ID>命令,向list集合中插入數據
  • 插入完成後再用LTRIM latest.comments 0 5000命令使其永遠只保存最近5000個ID
  • 然後我們在客戶端獲取某一頁評論時可以用下面的邏輯(僞代碼)
FUNCTION get_latest_comments(start,num_items):
    id_list = redis.lrange("latest.comments",start,start+num_items-1)
    IF id_list.length < num_items
        id_list = SQL_DB("SELECT ... ORDER BY time LIMIT ...")
    END
    RETURN id_list
END

如果你還有不同的篩選維度,比如某個分類的最新N條,那麼你可以再建一個按此分類的List,只存ID的話,Redis是非常高效的。

2.排行榜應用,取TOP N操作

這個需求與上面需求的不同之處在於,前面操作以時間爲權重,這個是以某個條件爲權重,比如按頂的次數排序,這時候就需要我們的sorted set出馬了,將你要排序的值設置成sorted set的score,將具體的數據設置成相應的value,每次只需要執行一條ZADD命令即可。

3.需要精準設定過期時間的應用

比如你可以把上面說到的sorted set的score值設置成過期時間的時間戳,那麼就可以簡單地通過過期時間排序,定時清除過期數據了,不僅是清除Redis中的過期數據,你完全可以把Redis裏這個過期時間當成是對數據庫中數據的索引,用Redis來找出哪些數據需要過期刪除,然後再精準地從數據庫中刪除相應的記錄。

4.計數器應用

Redis的命令都是原子性的,你可以輕鬆地利用INCR,DECR命令來構建計數器系統。

5.Uniq操作,獲取某段時間所有數據排重值

這個使用Redis的set數據結構最合適了,只需要不斷地將數據往set中扔就行了,set意爲集合,所以會自動排重。

6.實時系統,反垃圾系統

通過上面說到的set功能,你可以知道一個終端用戶是否進行了某個操作,可以找到其操作的集合並進行分析統計對比等。沒有做不到,只有想不到。

7.Pub/Sub構建實時消息系統

Redis的Pub/Sub系統可以構建實時的消息系統,比如很多用Pub/Sub構建的實時聊天系統的例子。

8.構建隊列系統

使用list可以構建隊列系統,使用sorted set甚至可以構建有優先級的隊列系統。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章