1 回答

TA貢獻1797條經驗 獲得超4個贊
Redis在很多方面與其他數據庫解決方案不同:它使用內存提供主存儲支持,而僅使用硬盤做持久性的存儲;它的數據模型非常獨特,用的是單線程。另一個大區別在于,你可以在開發環境中使用Redis的功能,但卻不需要轉到Redis。
轉向Redis當然也是可取的,許多開發者從一開始就把Redis作為首選數據庫;但設想如果你的開發環境已經搭建好,應用已經在上面運行了,那么更換數據庫框架顯然不那么容易。另外在一些需要大容量數據集的應用,Redis也并不適合,因為它的數據集不會超過系統可用的內存。所以如果你有大數據應用,而且主要是讀取訪問模式,那么Redis并不是正確的選擇。
然而我喜歡Redis的一點就是你可以把它融入到你的系統中來,這就能夠解決很多問題,比如那些你現有的數據庫處理起來感到緩慢的任務。這些你就可以通過Redis來進行優化,或者為應用創建些新的功能。在本文中,我就想探討一些怎樣將Redis加入到現有的環境中,并利用它的原語命令等功能來解決傳統環境中碰到的一些常見問題。在這些例子中,Redis都不是作為首選數據庫。
顯示最新的項目列表
下面這個語句常用來顯示最新項目,隨著數據多了,查詢毫無疑問會越來越慢。
復制代碼
代碼如下:
SELECT * FROM foo WHERE ... ORDER BY time
DESC LIMIT 10
在Web應用中,“列出最新的回復”之類的查詢非常普遍,這通常會帶來可擴展性問題。這令人沮喪,因為項目本來就是按這個順序被創建的,但要輸出這個順序卻不得不進行排序操作。
類似的問題就可以用Redis來解決。比如說,我們的一個Web應用想要列出用戶貼出的最新20條評論。在最新的評論邊上我們有一個“顯示全部”的鏈接,點擊后就可以獲得更多的評論。
我們假設數據庫中的每條評論都有一個唯一的遞增的ID字段。
我們可以使用分頁來制作主頁和評論頁,使用Redis的模板:
-每次新評論發表時,我們會將它的ID添加到一個Redis列表:
LPUSH latest.comments <ID>
-我們將列表裁剪為指定長度,因此Redis只需要保存最新的5000條評論:
LTRIM latest.comments 0 5000
-每次我們需要獲取最新評論的項目范圍時,我們調用一個函數來完成(使用偽代碼):
復制代碼
代碼如下:
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
這里我們做的很簡單。在Redis中我們的最新ID使用了常駐緩存,這是一直更新的。但是我們做了限制不能超過5000個ID,因此我們的獲取ID函數會一直詢問Redis。只有在start/count參數超出了這個范圍的時候,才需要去訪問數據庫。
我們的系統不會像傳統方式那樣“刷新”緩存,Redis實例中的信息永遠是一致的。SQL數據庫(或是硬盤上的其他類型數據庫)只是在用戶需要獲取“很遠”的數據時才會被觸發,而主頁或第一個評論頁是不會麻煩到硬盤上的數據庫了。
- 1 回答
- 0 關注
- 1652 瀏覽
添加回答
舉報