mongodb 使用場景和不使用場景
1.mongodb介紹
MongoDB (名稱來自"humongous") 是一個可擴充套件的高效能,開源,模式自由,面向文件的資料庫。它使用C++編寫。MongoDB特點:
a.面向集合的儲存:適合儲存物件及JSON形式的資料。
b.動態查詢:mongo支援豐富的查詢表達方式,查詢指令使用JSON形式的標記,可輕易查詢文件中的內嵌的物件及陣列。
c.完整的索引支援:包括文件內嵌物件及陣列。mongo的查詢最佳化器會分析查詢表示式,並生成一個高效的查詢計劃。
d.查詢監視:mongo包含一個監視工具用於分析資料庫操作效能。
e.複製及自動故障轉移:mongo資料庫支援伺服器之間的資料複製,支援主-從模式及伺服器之間的相互複製。複製的主要目的是提供冗餘及自動故障轉移。
f.高效的傳統儲存方式:支援二進位制資料及大型物件(如照片或圖片)。
g.自動分片以支援雲級別的伸縮性:自動分片功能支援水平的資料庫叢集,可動態新增額外的機器。
2.mongo使用場合
mongodb的主要目標是在鍵/值儲存方式(提供了高效能和高度伸縮性)以及傳統的RDBMS系統(豐富的功能)架起一座橋樑,集兩者的優勢於一身。mongo適用於以下場景:
a.網站資料:mongo非常適合實時的插入,更新與查詢,並具備網站實時資料儲存所需的複製及高度伸縮性。
b.快取:由於效能很高,mongo也適合作為資訊基礎設施的快取層。在系統重啟之後,由mongo搭建的持久化快取可以避免下層的資料來源過載。
c.大尺寸、低價值的資料:使用傳統的關聯式資料庫儲存一些資料時可能會比較貴,在此之前,很多程式設計師往往會選擇傳統的檔案進行儲存。
d.高伸縮性的場景:mongo非常適合由數十或者數百臺伺服器組成的資料庫。
e.用於物件及JSON資料的儲存:mongo的BSON資料格式非常適合文件格式化的儲存及查詢。
不適合的場景:
a.高度事物性的系統:例如銀行或會計系統。傳統的關係型資料庫目前還是更適用於需要大量原子性複雜事務的應用程式。
b.傳統的商業智慧應用:針對特定問題的BI資料庫會對產生高度最佳化的查詢方式。對於此類應用,資料倉儲可能是更合適的選擇。
c.需要SQL的問題。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/21601207/viewspace-745088/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL和Elasticsearch使用場景MySqlElasticsearch
- useCallback 和 useMemo 使用場景
- RabbitMQ 使用場景MQ
- Vuex使用場景Vue
- Block使用場景BloC
- Redis使用場景Redis
- retention guarantee使用場景和作用
- 典型使用者和場景
- RocketMQ場景使用技巧MQ
- git常用使用場景Git
- Map的使用場景
- Go Type 使用場景Go
- 聊聊Redis使用場景Redis
- 聊聊 Redis 使用場景Redis
- ruby 使用Struct場景Struct
- 泛型使用場景泛型
- grep 的使用場景
- ThreadLocal 原理和使用場景分析thread
- MongoDB的優勢和適用場景MongoDB
- 小程式使用場景:線上場景運用如何獲得使用者
- async函式使用場景函式
- 淺析 record 使用場景
- jeesz-zookeeper使用場景
- Redis都有哪些使用場景Redis
- 典型的ETL使用場景
- Android LaunchMode使用場景Android
- RxJava 使用場景小結RxJava
- 小程式使用最高效的場景:線上+線下混合場景
- 什麼場景適合mongodbMongoDB
- MongoDB 最佳實踐和場景避坑指南MongoDB
- ElasticSearch所使用的倒排索引的思想和使用場景Elasticsearch索引
- ThreadLocal的使用場景分析thread
- ES6 Symbol 使用場景Symbol
- fishhook使用場景&原始碼分析Hook原始碼
- Redis最常用的使用場景Redis
- zookeeper學習03 使用場景
- zookeeper使用(四)--應用場景
- MQ 常見的使用場景MQ