通常局限點來說,Redis也以訊息佇列的形式存在,作為內嵌的List存在,滿足即時的高並發需求。而通常在一個電商類型的資料處理過程之中,有關商品,熱銷,推薦排序的隊列,通常存放在Redis之中,期間也包擴Storm對於Redis列表的讀取和更新。
Redis是一個高效能的key-value資料庫。
Redis 與其他key - value 快取產品有以下三個特點:
- Redis支援資料的持久化,可以將記憶體中的資料保存在磁碟中,重新啟動的時候可以再次載入進行使用。
- Redis不僅支援簡單的key-value類型的數據,同時也提供list,set,zset,hash等資料結構的儲存。
- Redis支援資料的備份,即master-slave模式的資料備份。
五種用途:
1.全頁快取
整頁快取。如果你正在使用伺服器端呈現的內容,則不需要為每個單獨的請求重新渲染每個頁面。使用如Redis這樣的緩存,你可以快取經常請求的內容,從而大大減少請求最多的頁面的延遲,並且大多數框架針對Redis快取頁面都有hooks。
// 设置全页面缓存1分钟 SET key "<html>...</html>" EX 60 // 获取全页面 GET key
2.順序排列
由於Redis在記憶體中Set資料結構可以非常快速且有效率地進行遞增和遞減,效能遠高於SQL查詢。比較這與Redis的排序集相結合意味著你可以以毫秒為單位抓取清單中評分最高的項目,而且實現起來非常容易。
// 向排序集合中添加值 ZADD sortedSet 1 "one" // 从排序集合中获取所有值 ZRANGE sortedSet 0 -1 // 从排序集合中获取所有值与权重 ZRANGE sortedSet 0 -1 WITHSCORES
3.會話Session儲存
我所見的Redis最常見的用途是會話儲存。與其他會話儲存(如Memcache)不同,Redis可以保留數據,以便在快取停止的情況下,在重新啟動時,所有數據仍然存在。即便不是需要嚴格持續的任務,此功能仍可以為你的用戶省去大量的麻煩。沒有人會樂於看到他們的會話被無緣無故隨機刪除。
// 设置一分钟过期的session SET randomHash "{userId}" EX 60 // 获取用户ID GET randomHash
4.佇列
使用Redis可以做的一個不太常見,但非常有用的事情是排隊。無論是電子郵件佇列還是其他應用程式使用的數據,你都可以在Redis中建立一個高效率的佇列。任何熟悉堆疊以及會push和pop項目的開發人員都可以輕鬆自然地使用此功能。
// 添加消息 HSET messages <id> <message> ZADD due <due_timestamp> <id> // 接收消息 ZRANGEBYSCORE due -inf <current_timestamp> LIMIT 0 1 HGET messages <message_id> // 删除消息 ZREM due <message_id> HDEL messages <message_id>
5.pub/sub
Redis在真實世界的最終用法即我將在這篇文章中提出的pub / sub。這是Redis內建的最強大的功能之一;得到的可能是無限的。你可以建立一個即時聊天系統,在社群網路上觸發好友請求的通知等等。這個功能是Redis提供的最被低估的功能之一,但功能非常強大,而且使用簡單。
// 向通道中推送消息 PUBLISH channel message // 从通道中获取消息 SUBSCRIBE channel
以上是redis作用有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!