MongoDB 簡介

什麼是MongoDB ?

MongoDB 是由C++語言編寫的,是一個基於分散式檔案儲存的開源資料庫系統。

在高負載的情況下,新增更多的節點,可以保證伺服器效能。

MongoDB 旨在為WEB應用提供可擴充套件的高效能資料儲存解決方案。

MongoDB 將資料儲存為一個文件,資料結構由鍵值(key=>value)對組成。MongoDB 文件類似於 JSON 物件。欄位值可以包含其他文件,陣列及文件陣列。


主要特點

  • MongoDB 是一個面向文件儲存的資料庫,操作起來比較簡單和容易。
  • 你可以在MongoDB記錄中設定任何屬性的索引 (如:FirstName="Sameer",Address="8 Gandhi Road")來實現更快的排序。
  • 你可以通過本地或者網路建立資料映象,這使得MongoDB有更強的擴充套件性。
  • 如果負載的增加(需要更多的儲存空間和更強的處理能力) ,它可以分佈在計算機網路中的其他節點上這就是所謂的分片。
  • Mongo支援豐富的查詢表示式。查詢指令使用JSON形式的標記,可輕易查詢文件中內嵌的物件及陣列。
  • MongoDb 使用update()命令可以實現替換完成的文件(資料)或者一些指定的資料欄位 。
  • Mongodb中的Map/reduce主要是用來對資料進行批量處理和聚合操作。
  • Map和Reduce。Map函式呼叫emit(key,value)遍歷集合中所有的記錄,將key與value傳給Reduce函式進行處理。
  • Map函式和Reduce函式是使用Javascript編寫的,並可以通過db.runCommand或mapreduce命令來執行MapReduce操作。
  • GridFS是MongoDB中的一個內建功能,可以用於存放大量小檔案。
  • MongoDB允許在服務端執行指令碼,可以用Javascript編寫某個函式,直接在服務端執行,也可以把函式的定義儲存在服務端,下次直接呼叫即可。
  • MongoDB支援各種程式語言:RUBY,PYTHON,JAVA,C++,PHP,C#等多種語言。
  • MongoDB安裝簡單。

歷史

  • 2007年10月,MongoDB由10gen團隊所發展。2009年2月首度推出。
  • 2012年05月23日,MongoDB2.1 開發分支釋出了! 該版本採用全新架構,包含諸多增強。
  • 2012年06月06日,MongoDB 2.0.6 釋出,分散式文件資料庫。
  • 2013年04月23日,MongoDB 2.4.3 釋出,此版本包括了一些效能優化,功能增強以及bug修復。
  • 2013年08月20日,MongoDB 2.4.6 釋出。
  • 2013年11月01日,MongoDB 2.4.8 釋出。
  • ……

MongoDB 下載

你可以在mongodb官網下載該安裝包,地址為:https://www.mongodb.com/download-center#community。MonggoDB支援以下平臺:

  • OS X 32-bit
  • OS X 64-bit
  • Linux 32-bit
  • Linux 64-bit
  • Windows 32-bit
  • Windows 64-bit
  • Solaris i86pc
  • Solaris 64

語言支援

MongoDB有官方的驅動如下:

  • C
  • C++
  • C# / .NET
  • Erlang
  • Haskell
  • Java
  • JavaScript
  • Lisp
  • node.JS
  • Perl
  • PHP
  • Python
  • Ruby
  • Scala

MongoDB 工具

有幾種可用於MongoDB的管理工具。

監控

MongoDB提供了網路和系統監控工具Munin,它作為一個外掛應用於MongoDB中。

Gangila是MongoDB高效能的系統監視的工具,它作為一個外掛應用於MongoDB中。

基於圖形介面的開源工具 Cacti, 用於檢視CPU負載, 網路頻寬利用率,它也提供了一個應用於監控 MongoDB 的外掛。

GUI

  • Fang of Mongo – 網頁式,由Django和jQuery所構成。
  • Futon4Mongo – 一個CouchDB Futon web的mongodb山寨版。
  • Mongo3 – Ruby寫成。
  • MongoHub – 適用於OSX的應用程式。
  • Opricot – 一個基於瀏覽器的MongoDB控制檯, 由PHP撰寫而成。
  • Database Master — Windows的mongodb管理工具
  • RockMongo — 最好的PHP語言的MongoDB管理工具,輕量級, 支援多國語言.

MongoDB 應用案例

下面列舉一些公司MongoDB的實際應用:

  • Craiglist上使用MongoDB的存檔數十億條記錄。
  • FourSquare,基於位置的社交網站,在Amazon EC2的伺服器上使用MongoDB分享資料。
  • Shutterfly,以網際網路為基礎的社會和個人出版服務,使用MongoDB的各種永續性資料儲存的要求。
  • bit.ly, 一個基於Web的網址縮短服務,使用MongoDB的儲存自己的資料。
  • spike.com,一個MTV網路的聯營公司, spike.com使用MongoDB的。
  • Intuit公司,一個為小企業和個人的軟體和服務提供商,為小型企業使用MongoDB的跟蹤使用者的資料。
  • sourceforge.net,資源網站查詢,建立和釋出開源軟體免費,使用MongoDB的後端儲存。
  • etsy.com ,一個購買和出售手工製作物品網站,使用MongoDB。
  • 紐約時報,領先的線上新聞入口網站之一,使用MongoDB。
  • CERN,著名的粒子物理研究所,歐洲核子研究中心大型強子對撞機的資料使用MongoDB。