Redis詳解以及Redis的應用場景
Redis簡介
Redis 是完全開源免費的,遵守BSD協議,是一個高性能的key-value數據庫。 Redis 是一個強大的內存型存儲,具有豐富的數據結構,使其可以應用于很多方面,包括作為數據庫、緩存、消息隊列等等。
Redis 與其他 key - value 緩存產品有以下三個特點:
- Redis支持數據的持久化,可以將內存中的數據保存在磁盤中,重啟的時候可以再次加載進行使用。
- Redis不僅僅支持簡單的key-value類型的數據,同時還提供list,set,zset,hash等數據結構的存儲。
- Redis支持數據的備份,即master-slave模式的數據備份。
Redis 優勢:
- 性能極高 – Redis能讀的速度是110000次/s,寫的速度是81000次/s 。
- 豐富的數據類型 – Redis支持二進制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 數據類型操作。
- 原子 – Redis的所有操作都是原子性的,意思就是要么成功執行要么失敗完全不執行。單個操作是原子性的。多個操作也支持事務,即原子性,通過MULTI和EXEC指令包起來。
- 豐富的特性 – Redis還支持 publish/subscribe, 通知, key 過期等等特性。
Redis的5個常見應用場景
如果你的印象中Redis只是一個 key-value 存儲,那就錯過了Redis很多強大的功能,下面就是實際應用場景中5個最普遍的案例。
1. 全頁面緩存
如果你使用的是服務器端內容渲染,你又不想為每個請求重新渲染每個頁面,就可以使用 Redis 把常被請求的內容緩存起來,能夠大大的降低頁面請求的延遲,已經有很多框架用Redis來緩存頁面,這就是頁面靜態化的一種方式。
2. 排行榜
Redis 基于內存,可以非常快速高效的處理增加和減少的操作,相比于使用 SQL 請求的處理方式,性能的提升是非常巨大的。
Redis 的有序集合可以輕松實現“從一個大型列表中取得排名***的N個元素”,毫秒級,而且非常簡單。
3. Session 存儲
這可能是應用最廣的點了,相比較于類似 memcache 的 session 存儲,Redis 具有緩存數據持久化的能力,當緩存因出現問題而重啟后,之前的緩存數據還在那兒,這個就比較實用,避免了因為session突然消失帶來的用戶體驗問題。
4. 隊列
例如 email 的發送隊列、等待被其他應用消費的數據隊列,Redis 可以輕松而自然的創建出一個高效的隊列。
5.發布/訂閱
pub/sub 是 Redis 內置的一個非常強大的特性,例如可以創建一個實時的聊天系統、社交網絡中的通知觸發器等等。