歡迎您光臨本站 註冊首頁

8種Nosql資料庫系統對比

←手機掃碼閱讀     火星人 @ 2014-03-12 , reply:0
  

 導讀: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+/秒),通過鍵值索引數據
  • 可持久化存儲到硬碟
  • 所有節點都是唯一的( master-master複製)


[火星人 ] 8種Nosql資料庫系統對比已經有485次圍觀

http://coctec.com/news/soft/show-post-74044.html