8種Nosql資料庫系統對比(轉)

來源:互聯網
上載者:User
關鍵字 nbsp; 複製 適用于

8種Nosql資料庫系統對比 


原文:Kristóf Kovács 編輯:敏捷翻譯:唐尤華 





分享到: 更多 導讀:Kristóf Kovács 是一位軟體架構師和諮詢顧問,他最近發佈了一片對比各種類型nosql資料庫的文章。 文章由敏捷翻譯 – 唐尤華編譯。 如需轉載,請參見文後聲明。 





雖然SQL資料庫是非常有用的工具,但經歷了15年的一支獨秀之後壟斷即將被打破。 這只是時間問題:被迫使用關係資料庫,但最終發現不能適應需求的情況不勝枚舉。 





但是NoSQL資料庫之間的不同,遠超過兩 SQL資料庫之間的差別。 這意味著軟體架構師更應該在專案開始時就選擇好一個適合的 NoSQL資料庫。 針對這種情況,這裡對 Cassandra、 Mongodb、CouchDB、Redis、 Riak、 Membase、Neo4j和HBase進行了比較: 





(編注1:NoSQL:是一項全新的資料庫革命性運動,NoSQL的擁護者們提倡運用非關聯式的資料存儲。 現今的電腦體系結構在資料存儲方面要求具 備龐大的水準擴 展性,而NoSQL致力於改變這一現狀。 目前Google的 BigTable 和Amazon 的Dynamo使用的就是NoSQL型資料庫。 參見NoSQL詞條。 ) 











1. CouchDB 





•所用語言: Erlang 


•特點:DB一致性,便於使用 


•使用許可: Apache 


•協定: HTTP/REST 


•雙向資料複製, 


•持續進行或臨時處理, 


•處理時帶衝突檢查, 


•因此,採用的是master-master複製(見編注2) 


•MVCC – 寫操作不阻塞讀操作 


•可保存檔之前的版本 


•Crash-only(可靠的)設計 


•需要不時地進行資料壓縮 


•視圖:嵌入式 映射/減少 


•格式化視圖:清單顯示 


•支援進行伺服器端文檔驗證 


•支援認證 


•根據變化即時更新 


•支援附件處理 


•因此, CouchApps(獨立的 js應用程式) 


•需要 jQuery程式庫 








最佳應用場景:適用于資料變化較少,執行預定義查詢,進行資料統計的應用程式。 適用于需要提供資料版本支援的應用程式。 





例如: CRM、CMS系統。 master-master複製對於多網站部署是非常有用的。 





(編注2:master-master複製:是一種資料庫同步方法,允許資料在一組電腦之間共用資料,並且可以通過小組中任意成員在組內進行資料更新。 ) 











2. Redis 





•所用語言:C/C++ 


•特點:運行異常快 


•使用許可: BSD 


•協定:類 Telnet 


•有硬碟存儲支援的記憶體資料庫, 


•但自2.0版本以後可以將資料交換到硬碟(注意, 2.4以後版本不支援該特性! ) 


•Master-slave複製(見編注3) 


•雖然採用簡單資料或以鍵值索引的雜湊表,但也支援複雜操作,例如 ZREVRANGEBYSCORE。 


•INCR & co (適合計算極限值或統計資料) 


•支援 sets(同時也支援 union/diff/inter) 


•支援清單(同時也支援佇列;阻塞式 pop操作) 


•支援雜湊表(帶有多個域的物件) 


•支援排序 sets(高得分表,適用于範圍查詢) 


•Redis支援事務 


•支援將資料設置成過期資料(類似快速緩衝區設計) 


•Pub/Sub允許使用者實現消息機制 








最佳應用場景:適用于資料變化快且資料庫大小可遇見(適合記憶體容量)的應用程式。 





例如:股票價格、資料分析、即時資料搜集、即時通訊。 





(編注3:Master-slave複製:如果同一時刻只有一台伺服器處理所有的複製請求,這被稱為 Master-slave複製,通常應用在需要提供高可用性的伺服器集群。 ) 











3. MongoDB 





•所用語言:C++ 


•特點:保留了SQL一些友好的特性(查詢,索引)。 


•使用許可: AGPL(發起者: Apache) 


•協定: Custom, binary( BSON) 


•Master/slave複製(支援自動錯誤恢復,使用 sets 複製) 


•內建分片機制 


•支援 javascript運算式查詢 


•可在伺服器端執行任意的 javascript函數 


•update-in-place支援比CouchDB更好 


•在資料存儲時採用記憶體到檔案對應 


•對性能的關注超過對功能的要求 


•建議最好打開日誌功能(參數 –journal) 


•在32位作業系統上,資料庫大小限制在約2.5Gb 


•空資料庫大約占 192Mb 


•採用 GridFS存儲大資料或中繼資料(不是真正的檔案系統) 








最佳應用場景:適用于需要動態查詢支援;需要使用索引而不是 map/reduce功能;需要對大資料庫有性能要求;需要使用 CouchDB但因為資料改變太頻繁而占滿記憶體的應用程式。 





例如:你本打算採用 MySQL或 PostgreSQL,但因為它們本身自帶的預定義欄讓你望而卻步。 











4. Riak 





•所用語言:Erlang和C,以及一些JAVAscript 


•特點:具備容錯能力 


•使用許可: Apache 


•協定: HTTP/REST或者 custom binary 


•可調節的分發及複製(N, R, W) 


•用 JavaScript or Erlang在操作前或操作後進行驗證和安全支援。 


•使用JavaScript或Erlang進行 Map/reduce 


•連接及連接遍歷:可作為圖形資料庫使用 


•索引:輸入中繼資料進行搜索(1.0版本即將支援) 


•大資料物件支援( Luwak) 


•提供「開源」和「企業」兩個版本 


•全文本搜索,索引,通過 Riak搜尋伺服器查詢( Beta版) 


•支援Masterless多網站複製及商業許可的 SNMP監控 








最佳應用場景:適用于想使用類似 Cassandra(類似Dynamo)資料庫但無法處理 bloat及複雜性的情況。 適用于你打算做多網站複製,但又需要對單個網站的擴充性,可用性及出錯處理有要求的情況。 





例如:銷售資料搜集,工廠控制系統;對宕機時間有嚴格要求;可以作為易於更新的 web伺服器使用。 





5. Membase 





•所用語言: Erlang和C 


•特點:相容 Memcache,但同時兼具持久化和支援集群 


•使用許可: Apache 2.0 


•協定:分散式緩存及擴展 


•非常快速(200k+/秒),通過鍵值索引資料 


•可持久化存儲到硬碟 


相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.