美文网首页java数据存储
MongoDB的适用场景及优缺点

MongoDB的适用场景及优缺点

作者: 一只小星_ | 来源:发表于2019-07-08 14:34 被阅读0次

MongoDB文档型数据库,现将MongoDB比较适用的场景做一个总结,供参考。

1、各种应用服务的日志存储,MongoDB的高性能足够支撑关系型数据库2-3倍以上的TPS/QPS,同时自带的三种压缩格式方便在容量和性能直接作出选择,通过MongoDB存储日志文件,查询简单(索引),写入导出方便(弹性结构没有表结构限制)。
2、敏捷开发,如果想快速构建应用系统,同时还想拥有高性能,高灵活性的schema,用MongoDB吧。
3、地理位置信息存储,通过2d和2dsphere索引,可以方便的查询出具体的位置信息。
4、json存储,json的数据结构简单、直观,非常适合用来表达数据,且易于阅读、扩展。

其实并没有什么业务场景是一定要MongoDB才能支持的,但是MongoDB往往能在同等的成本下发挥更好的作用(灵活性、性能等),如下是MongoDB的一些主要特性:
1、事务支持 MongoDB 目前只支持单文档事务,需要复杂事务支持的场景暂时不适合。
PS:4.0版本已经GA,已经支持ACID事务。
2、灵活的文档模型,JSON 格式存储最接近真实对象模型,对开发者友好,方便快速开发迭代。
3、高可用复制集,满足数据高可靠、服务高可用的需求,运维简单,故障自动切换。
4、可扩展分片集群,海量数据存储,服务能力水平扩展。
5、高性能,mmapv1、wiredtiger、mongorocks(rocksdb)、in-memory 等多引擎支持满足各种场景需求。
6、强大的索引支持 地理位置索引可用于构建 各种 O2O 应用、文本索引解决搜索的需求、TTL索引解决历史数据自动过期的需求。
7、Gridfs,解决文件存储的需求。
8、aggregation & mapreduce,解决数据分析场景需求,用户可以自己写查询语句或脚本,将请求都分发到 MongoDB 上完成。

如果你还在为是否应该使用 MongoDB,不如来做几个选择题来辅助决策(注:以下内容摘自 MongoDB公司的某次公开技术分享)。


如果上述有1个 Yes,可以考虑 MongoDB,2个及以上的 Yes,选择 MongoDB 绝不会后悔。

相关文章

  • MongoDB的适用场景及优缺点

    MongoDB文档型数据库,现将MongoDB比较适用的场景做一个总结,供参考。 1、各种应用服务的日志存储,Mo...

  • MongoDB、ElasticSearch、Redis、HBas

    MongoDB、ElasticSearch、Redis、HBase这四种热门数据库的优缺点及应用场景 麦田里的老农...

  • 优缺点及适用场景讨论

    概述:NodeJS宣称其目标是“旨在提供一种简单的构建可伸缩网络程序的方法”,那么它的出现是为了解决什么问题呢,它...

  • MongoDB适用场景

    更高的写入负载 默认情况下,MongoDB更侧重高数据写入性能,而非事务安全,MongoDB很适合业务系统中有大量...

  • MongoDB 适用场景

    MongoDB (名称来自"humongous") 是一个可扩展的高性能,开源,模式自由,面向文档的数据库。Mon...

  • MongoDB适用业务场景

    一、web 应用程序 web应用的业务特点是读写请求都比较高,数据存储需要适应业务的扩展。传统的关系型数据库...

  • MongoDB适用什么场景?

    自加入项目以来,一直觉得MongoDB不太适合做业务系统的主数据库,它是导致目前主要的逻辑都是面向JSON的数据处...

  • [NodeJS] 优缺点及适用场景讨论

    [NodeJS] 优缺点及适用场景讨论 概述: NodeJS宣称其目标是“旨在提供一种简单的构建可伸缩网络程序的方...

  • 选择合适的IPC方式

    参考Android开发艺术探索 IPC 方式的优缺点和适用场景 名称优点缺点适用场景Bundle简单易用只能传输B...

  • MongoDB及其适用场景

    概念特征:MongoDB是一个基于分布式文件存储的数据库,由C++编写,使用二进制数据存储,文件存储格式为BSON...

网友评论

    本文标题:MongoDB的适用场景及优缺点

    本文链接:https://www.haomeiwen.com/subject/dtiohctx.html