Redis學習筆記

來源:互聯網
上載者:User

標籤:

以前,一直拿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學習筆記

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.