除了用作緩存數據,Redis還可以做這些


Redis應該說是目前最受歡迎的NoSQL數據庫之一了。Redis通常被作為緩存組件,用作緩存數據。不過,除了可以緩存數據,其實Redis可以做的事還有很多。下面列舉幾例,供大家參考。

1、最新列表

例如新聞列表頁面最新的新聞列表,如果總數量很大的情況下,盡量不要使用select a from A limit 10,嘗試redis的 LPUSH命令構建List,一個個順序都塞進去就可以啦。不過萬一內存清掉了咋辦?也簡單,查詢不到存儲key的話,用mysql查詢並且初始化一個List到redis中就好了。

2、排行榜應用

實現這個功能主要用到的redis數據類型是redis的有序集合zset。zset 是set 類型的一個擴展,比原有的類型多了一個順序屬性,此屬性在每次插入數據時會自動調整順序值,保證value值按照一定順序連續排列。

我們假設是一個游戲經驗值排行榜,那主要的實現思路是:

  • 1、在一個新的玩家參與到游戲中時,在redis中的zset中新增一條記錄(記錄內容看具體的需求)score為0

  • 2、當玩家的經驗值發生變化時,修改該玩家的score值

  • 3、使用redis的ZREVRANGE方法獲取排行榜

3、計數器應用

Redis的命令都是原子性的,你可以輕松地利用INCR、DECR命令進行原子性操作,來構建計數系統。由於單線程,可以避免並發問題,保證不會出錯,而且100%毫秒級性能。

比如在一個 web 應用程序中,如果想知道用戶在一年中每天的點擊量,那么只要將用戶 ID 以及相關的日期信息作為鍵,並在每次用戶點擊頁面時,執行一次自增操作即可。

4、數據排重

Redis set是可以自動排重的,當你需要存儲一個列表數據,又不希望出現重復數據時,set是一個很好的選擇,並且set提供了判斷某個成員是否在一個set集合內的重要接口。

實現方案:

set 的內部實現是一個 value永遠為null的HashMap,實際就是通過計算hash的方式來快速排重的,這也是set能提供判斷一個成員是否在集合內的原因。

5、實時的反垃圾系統

反垃圾系統通常都是基於關鍵詞的,使用Redis儲存關系詞,能夠利用Redis的高性能,為監控系統提供穩定及精確的實時監控功能,典型的案例如,郵件系統、評論系統等。

6、可以發布、訂閱的實時消息系統

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

設計思路:

  1. 服務端發送消息(含標題,內容),標題按照一定規則存入redis,同時標題(以最少的信息量)推送到客戶端,客戶點擊標題時,獲取相應的內容閱讀.

  2. 如果未讀取,可以提示多少條未讀,redis能夠很快記數

  3. 根據一定時間清理緩存

技術實現:

  • 需要redis數據庫,客戶端websocket,服務器端websocket

7、隊列應用

隊列在現在程序中應用十分廣泛,比如日志推送、任務處理等等。以往通常使用http sqs實現隊列,其實,使用redis的list類型,也可以實現隊列。

示例如下:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM