標籤:
以前,一直拿redis當memcached來用,今天才真天瞭解到了Redis真正比memcached強大到了什麼地方,他的真正的強勢到了什麼地方。
首先最讓我困惑的一點是,Redis是所有資料都儲存到記憶體裡面的嗎?這讓我費解,如果是,何來keys存在記憶體,從而提高效能。我很困惑,看了RDB、AOF以後,發現不像是資料的儲存查詢資料庫檔案。後來我決定重新學習Redis相關資料,得到的總結如下:
Redis裡的資料存放區在哪裡了?
Redis的Key是絕對儲存在記憶體裡面的,這也是Redis高效能的一個依仗,哪麼Value存到什麼地方了?預設是存在Virtual Memery裡面了,所謂虛擬記憶體,需要注意的是,這裡的虛擬記憶體並不是系統的虛擬記憶體,而是Redis裡的一個資料存放區檔案,這尼馬讓我鬱悶良久。因為Redis裡可以設定vm.swap檔案的存放目錄。
Redis的記憶體的流量分析
Redis為什麼叫資料庫檔案叫虛擬記憶體,不叫資料庫檔案,這大有文章,所謂Redis的設計理念上資料是儲存在記憶體中設計的,因為就算設定了虛擬記憶體,Redis會自動將熱的資料放在記憶體,直接提供讀取,把經常不讀的資料放到虛擬記憶體中,從而提高效能。而Keys裡己經記錄了虛擬記憶體檔案中的定址資料,讀取也是比一般資料庫要快很多倍的。
Redis的叢集
http://www.redis.cn/topics/cluster-tutorial.html
redis分區,Redis高可用性,Redis主從備份,可以參考上文中,Redis-trip工具實現Redis-cluster真正叢集。
Redis分區是通過雜湊演算法將key區分幾個區間,然後由劃分庫或伺服器實現分區的。通過redis-trip工具實現非常智能。
Redis的儲存結構
Redis支援Map、List、string、int等資料類型,為了減少Key的數量,減少記憶體的使用,合理使用Map、List可以減少記憶體和清晰程式邏輯。
Redis的可靠性
Redis官方就宣稱Redis並不是一個資料絕對安全的資料存放區引擎,當儲存時Redis會先儲存到記憶體,就返回了狀態,在這期間並沒有寫入磁碟,這很有可能資料就沒有了,但只因為這樣,Redis的效能大大提升,減少了磁碟的寫入頻率。
Redis應用情境
Redis完全可以做資料快取資料庫、時時計數、時時統計
Redis學習筆記