MongoDB 教程


閱讀(987.6k) 收藏 (206)

手冊簡介

Mongo DB 是目前在IT行業(yè)非常流行的一種非關(guān)系型數(shù)據(jù)庫(NoSql)。

手冊說明

201610251630158001

MongoDB是什么?

MongoDB 是一個基于分布式文件存儲的數(shù)據(jù)庫。由C++語言編寫。旨在為WEB應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲解決方案。

MongoDB是一個介于關(guān)系數(shù)據(jù)庫和非關(guān)系數(shù)據(jù)庫之間的產(chǎn)品,是非關(guān)系數(shù)據(jù)庫當(dāng)中功能最豐富,最像關(guān)系數(shù)據(jù)庫的。他支持的數(shù)據(jù)結(jié)構(gòu)非常松散,是類似json的bson格式,因此可以存儲比較復(fù)雜的數(shù)據(jù)類型。Mongo最大的特點(diǎn)是他支持的查詢語言非常強(qiáng)大,其語法有點(diǎn)類似于面向?qū)ο蟮牟樵冋Z言,幾乎可以實現(xiàn)類似關(guān)系數(shù)據(jù)庫單表查詢的絕大部分功能,而且還支持對數(shù)據(jù)建立索引。

MongoDB有什么特點(diǎn)?

它的特點(diǎn)是高性能、易部署、易使用,存儲數(shù)據(jù)非常方便。主要功能特性有:

  • 面向集合存儲,易存儲對象類型的數(shù)據(jù)。
  • 模式自由。
  • 支持動態(tài)查詢。
  • 支持完全索引,包含內(nèi)部對象。
  • 支持查詢。
  • 支持復(fù)制和故障恢復(fù)。
  • 使用高效的二進(jìn)制數(shù)據(jù)存儲,包括大型對象(如視頻等)。
  • 自動處理碎片,以支持云計算層次的擴(kuò)展性
  • 支持Ruby,python,Java,C++,PHP,C#等多種語言。
  • 文件存儲格式為BSON(一種JSON的擴(kuò)展)。
  • 可通過網(wǎng)絡(luò)訪問。

MongoDB使用原理是什么?

所謂“面向集合”(Collection-Oriented),意思是數(shù)據(jù)被分組存儲在數(shù)據(jù)集中,被稱為一個集合(Collection)。每個集合在數(shù)據(jù)庫中都有一個唯一的標(biāo)識名,并且可以包含無限數(shù)目的文檔。集合的概念類似關(guān)系型數(shù)據(jù)庫(RDBMS)里的表(table),不同的是它不需要定義任何模式(schema)。Nytro MegaRAID技術(shù)中的閃存高速緩存算法,能夠快速識別數(shù)據(jù)庫內(nèi)大數(shù)據(jù)集中的熱數(shù)據(jù),提供一致的性能改進(jìn)。模式自由(schema-free),意味著對于存儲在mongodb數(shù)據(jù)庫中的文件,我們不需要知道它的任何結(jié)構(gòu)定義。如果需要的話,你完全可以把不同結(jié)構(gòu)的文件存儲在同一個數(shù)據(jù)庫里。存儲在集合中的文檔,被存儲為鍵-值對的形式。鍵用于唯一標(biāo)識一個文檔,為字符串類型,而值則可以是各種復(fù)雜的文件類型。我們稱這種存儲形式為BSON(Binary Serialized Document Format)。

MongoDB適用場景

MongoDB 的主要目標(biāo)是在鍵/值存儲方式(提供了高性能和高度伸縮性)和傳統(tǒng)的RDBMS 系統(tǒng)(具有豐富的功能)之間架起一座橋梁,它集兩者的優(yōu)勢于一身。

Mongo 適用于以下場景:

● 網(wǎng)站數(shù)據(jù):Mongo 非常適合實時的插入,更新與查詢,并具備網(wǎng)站實時數(shù)據(jù)存儲所需的復(fù)制及高度伸縮性。

● 緩存:由于性能很高,Mongo 也適合作為信息基礎(chǔ)設(shè)施的緩存層。在系統(tǒng)重啟之后,由Mongo 搭建的持久化緩存層可以避免下層的數(shù)據(jù)源過載。

● 大尺寸、低價值的數(shù)據(jù):使用傳統(tǒng)的關(guān)系型數(shù)據(jù)庫存儲一些數(shù)據(jù)時可能會比較昂貴,在此之前,很多時候程序員往往會選擇傳統(tǒng)的文件進(jìn)行存儲。

● 高伸縮性的場景:Mongo 非常適合由數(shù)十或數(shù)百臺服務(wù)器組成的數(shù)據(jù)庫,Mongo 的路線圖中已經(jīng)包含對MapReduce 引擎的內(nèi)置支持。

● 用于對象及JSON 數(shù)據(jù)的存儲:Mongo 的BSON 數(shù)據(jù)格式非常適合文檔化格式的存儲及查詢。

MongoDB 的使用也會有一些限制,例如,它不適合于以下幾個地方。

● 高度事務(wù)性的系統(tǒng):例如,銀行或會計系統(tǒng)。傳統(tǒng)的關(guān)系型數(shù)據(jù)庫目前還是更適用于需要大量原子性復(fù)雜事務(wù)的應(yīng)用程序。

● 傳統(tǒng)的商業(yè)智能應(yīng)用:針對特定問題的BI 數(shù)據(jù)庫會產(chǎn)生高度優(yōu)化的查詢方式。對于此類應(yīng)用,數(shù)據(jù)倉庫可能是更合適的選擇。

● 需要SQL 的問題。

Mongo不適用的場景如下:

  1. 要求高度事務(wù)性的系統(tǒng)。
  2. 傳統(tǒng)的商業(yè)智能應(yīng)用。
  3. 復(fù)雜的跨文檔(表)級聯(lián)查詢。

MongoDB應(yīng)用案例

  •  Craiglist上使用MongoDB的存檔數(shù)十億條記錄。
  •  FourSquare,基于位置的社交網(wǎng)站,在Amazon EC2的服務(wù)器上使用MongoDB分享數(shù)據(jù)。
  •  Shutterfly,以互聯(lián)網(wǎng)為基礎(chǔ)的社會和個人出版服務(wù),使用MongoDB的各種持久性數(shù)據(jù)存儲的要求。
  •  bit.ly, 一個基于Web的網(wǎng)址縮短服務(wù),使用MongoDB的存儲自己的數(shù)據(jù)。
  •  spike.com,一個MTV網(wǎng)絡(luò)的聯(lián)營公司, spike.com使用MongoDB的。
  •  Intuit公司,一個為小企業(yè)和個人的軟件和服務(wù)提供商,為小型企業(yè)使用MongoDB的跟蹤用戶的數(shù)據(jù)。
  •  sourceforge.net,資源網(wǎng)站查找,創(chuàng)建和發(fā)布開源軟件免費(fèi),使用MongoDB的后端存儲。
  •  etsy.com ,一個購買和出售手工制作物品網(wǎng)站,使用MongoDB。
  •  紐約時報,領(lǐng)先的在線新聞門戶網(wǎng)站之一,使用MongoDB。
  •  CERN,著名的粒子物理研究所,歐洲核子研究中心大型強(qiáng)子對撞機(jī)的數(shù)據(jù)使用MongoDB。

MongoDB相關(guān)教程

《The Little MongoDB Book 中文版》

附加資料

MongoDB官網(wǎng):https://www.mongodb.com/

MongoDB官方文檔:https://docs.mongodb.com/

MongoDB教程:http://hgci.cn/mongodb/mongodb-intro.html

MongoDB下載:https://docs.mongodb.com/




更新記錄

在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號