MongoDB基本概念

来源:互联网 发布:淘宝 比价网 编辑:程序博客网 时间:2024/05/21 08:35

什么是MongoDB?
MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。

MongoDB的特点:
它的特点是高性能、易部署、易使用,存储数据非常方便。
1、面向集合存储,容易存储对象类型的数据。在MongoDB 中数据被分组存储在集合中,集合类似RDBMS 中的表,一个集合中可以存储无限多的文档。
2、模式自由,采用无模式结构存储。在MongoDB 中集合中存储的数据是无模式的文档,采用无模式存储数据是集合区别于RDBMS 中的表的一个重要特征。
3、支持完全索引,可以在任意属性上建立索引,包含内部对象。MongoDB的索引和RDBMS 的索引基本一样,可以在指定属性、内部对象上创建索引以提高查询的速度。除此之外,MongoDB 还提供创建基于地理空间的索引的能力。
4、支持查询。MongoDB 支持丰富的查询操作,MongoDB 几乎支持SQL中的大部分查询。
5、强大的聚合工具。MongoDB 除了提供丰富的查询功能外,还提供强大的聚合工具,如count、group 等,支持使用MapReduce 完成复杂的聚合任务。
6、支持复制和数据恢复。MongoDB 支持主从复制机制,可以实现数据备份、故障恢复、读扩展等功能。而基于副本集的复制机制提供了自动故障恢复的功能,确保了集群数据不会丢失。
7、使用高效的二进制数据存储,包括大型对象(如视频)。使用二进制格式存储,可以保存任何类型的数据对象。
8、自动处理碎片,以支持云计算层次的扩展。MongoDB 支持集群自动切分数据,对数据进行分片可以使集群存储更多的数据,实现更大的负载,也能保证存储的负载均衡。
9、支持Perl、PHP、Java、C#、JavaScript、Ruby、C 和C++语言的驱动程序,MongoDB 提供了当前所有主流开发语言的数据库驱动包,开发人员使用任何一种主流开发语言都可以轻松编程,实现访问MongoDB 数据库。
10、文件存储格式为BSON(JSON 的一种扩展)。BSON 是对二进制格式的JSON 的简称,BSON 支持文档和数组的嵌套。
11、可以通过网络访问。可以通过网络远程访问MongoDB 数据库。

MongoDB部署的场景:
1、网站实时数据处理。它非常适合实时的插入、更新与查询,并具备网站实时数据存储所需的复制及高度伸缩性。
2、缓存。由于性能很高,它适合作为信息基础设施的缓存层。在系统重启之后,由它搭建的持久化缓存层可以避免下层的数据源过载。
3、高伸缩性的场景。非常适合由数十或数百台服务器组成的数据库,它的路线图中已经包含对MapReduce引擎的内置支持。

不适合使用MongoDB部署的场景:
1、要求高度事务性的系统。2、传统的商业智能应用。3、复杂的跨文档(表)级联查询。

数据库总结:
A.文档式数据库:节省空间,很多的需求符合mongoDB的设计,查询速度很快
B.关系型数据库:MySQL,事务的处理,比如登录密码的存储
C.非关系型数据库(NoSQL):
1、Redis(键值对的数据库—基于内存的数据库,查询和读取比较快,数据的结构比较丰富)
2、MongDB可以搭建集群
3、memcached结构比较单一,为了查询\检查、分享
4、HBase 列式数据库,做大数据分析,很多时候,都是某一列的内容进行分析——facebook

原创粉丝点击