Redis 11種Web應用場景舉例

2022-01-30 14:25:19 字數 1554 閱讀 5623

在「怎樣讓redis在你的系統中發揮作用」一文中,salvatore 'antirez』 sanfilippo告訴我們如何利用redis獨有的資料結構處理能力來解決一些常見問題。一些redis原語命令比如lpush、ltrim和lrem等等能夠用來幫助開發者完成需要的任務——這些任務在傳統的資料庫儲存中非常困難或緩慢。這是一篇非常有用並且實際的文章。那麼要如何在你的框架中完成這些任務呢?

下面列出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的11種Web應用場景簡介

下面列出11種web應用場景,在這些場景下可以充分的利用redis的特性,大大提高效率。1.在主頁中顯示最新的專案列表 redis使用的是常駐記憶體的快取,速度非常快。lpush用來插入乙個內容id,作為關鍵字儲存在列表頭部。ltrim用來限制程式設計客棧列表中的專案數最多為5000。如果使用者需要...

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

2011 07 25 10 38 賈隆 51cto.com 字型大小 t t redis的乙個很大好處就是可以不用整個轉入到這個資料庫,而是可以沿用之前的mysql等資料庫,而僅在一些特定的應用場景通過redis的特性提高效率。本文列出了11個這樣的web應用場景,如顯示最新的專案列表 刪除和過濾 ...

Redis應用場景

redis開創了一種新的資料儲存思路,使用redis,我們不用在面對功能單調的資料庫時,把精力放在如何把大象放進冰箱這樣的問題上,而是利用redis靈活多變的資料結構和資料操作,為不同的大象構建不同的冰箱。redis常用資料型別 redis最為常用的資料型別主要有以下五種 在具體描述這幾種資料型別之...