原文地址:http://www.mongoing.com/archives/3609mysql
案例1sql
案例2数据库
MongoDB以前有用过,主要用来存储一些监控数据,No schema 对开发人员来讲,真的很方便,增长字段不用改表结构,并且学习成本极低。数组
案例3服务器
使用MongoDB作了O2O快递应用,将送快递骑手、快递商家的信息(包含位置信息)存储在MongoDB,而后经过 MongoDB的地理位置查询,这样很方便的实现了查找附近的商家、骑手等功能,使得快递骑手能就近接单,目前在使用MongoDB上没遇到啥大的问题,官网的文档比较详细,很给力。微信
常常跟一些同窗讨论MongoDB业务场景时,会听到相似【你这个场景 mysql 也能解决,不必必定用 MongoDB】的声音,的确,并无某个业务场景必需要使用 MongoDB才能解决,但使用 MongoDB 一般能让你以更低的成本解决问题(包括学习、开发、运维等成本),下面是 MongoDB 的主要特性,你们能够对照本身的业务需求看看,匹配的越多,用 MongoDB 就越合适。markdown
MONGODB 特性 | 优点 |
---|---|
事务支持 | MongoDB 目前只支持单文档事务,须要复琐事务支持的场景暂时不适合。 |
灵活的文档模型 | JSON 格式存储最接近真实对象模型,对开发者友好,方便快速开发迭代。 |
高可用复制集 | 知足数据高可靠、服务高可用的需求,运维简单,故障自动切换。 |
可扩展分片集群 | 海量数据存储,服务能力水平扩展。 |
高性能 | mmapv一、wiredtiger、mongorocks(rocksdb)、in-memory 等多引擎支持知足各类场景需求 |
强大的索引支持 | 地理位置索引可用于构建 各类 O2O 应用、文本索引解决搜索的需求、TTL索引解决历史数据自动过时的需求。 |
Gridfs | 解决文件存储的需求 |
aggregation & mapreduce | 解决数据分析场景需求,用户能够本身写查询语句或脚本,将请求都分发到 MongoDB 上完成。 |
从目前阿里云MongoDB云数据库上的用户看,MongoDB 的应用已经渗透到各个领域,好比游戏、物流、电商、内容管理、社交、物联网、视频直播等,如下是几个实际的应用案例。less
若是你还在为是否应该使用MongoDB,不如来作几个选择题来辅助决策(注:如下内容改编自MongoDB公司TJ同窗的某次公开技术分享)。运维
应用特征 | YES / NO |
---|---|
应用不须要事务及复杂 join 支持 | 必须 Yes |
新应用,需求会变,数据模型没法肯定,想快速迭代开发 | ? |
应用须要2000-3000以上的读写QPS(更高也能够) | ? |
应用须要TB甚至 PB 级别数据存储 | ? |
应用发展迅速,须要能快速水平扩展 | ? |
应用要求存储的数据不丢失 | ? |
应用须要99.999%高可用 | ? |
应用须要大量的地理位置查询、文本查询 | ? |
若是上述有1个 Yes,能够考虑 MongoDB,2个及以上的 Yes,选择 MongoDB 毫不会后悔。性能
若是读完以为有收获的话,欢迎点赞、关注、加公众号【牛觅技术】,查阅更多精彩历史!!!: