对于希望使用MongoDB的组织,学习如何可以压倒:哪里,你是怎么开始使用这个强大的数据库?随着数据库的普及,IT领导者需要清楚地了解其基础以及更好的使用技巧。
对于希望使用分布式文件存储的数据库MongoDB的组织来说,如何开始使用这个强大的数据库是其所面临的挑战。随着数据库的普及,IT领导者需要对其基础有一个清晰的了解以及更好的使用技巧。
以下是确保成功应用MongoDB数据库的五个简单步骤。
步骤1:了解基础知识
MongoDB是采用C,C++和Java Script编程语言编写的。它是Oracle,,MySQL和MS-SQL之后的第四大数据库管理系统(已经上市20到30年),它是最流行的文件存储数据库之一。MongoDB以提供高性能,高可用性和易扩展性而闻名。它适用于许多平台,并具有许多语言驱动程序。
面向文档的数据库是一种用于存储,检索和管理面向文档信息的计算机程序。面向文档的数据库是NoSQL数据库的主要类别。MongoDB是一种面向文档的数据库,它意味着所有内容都以文档的形式从数据库中进行检索,而不像关系型数据库那样是以行为的形式。
MongoDB数据库中的文档并不是通常使用的Word或文本文件,而是JSON格式的文件。MongoDB属于面向文档的NoSQL数据库。
步骤2:了解概念
以下有三个主要概念描述面向文档的数据库包括的内容:
(1)数据库:MongoDB将数据进行排列,就像大多数关系数据库一样。在RDBMS(关系数据库管理系统)中,数据库是一组表,存储过程,视图等。在MongoDB中,数据库是一组集合。MongoDB数据库包含一个或多个集合。
(2)集合:这个集合相当于RDBMS表。集合中的文档可以有不同的字段。通常,集合中的所有文档具有相似或相关的用途。
(3)文件:MongoDB集合中的记录以及MongoDB中的基本数据单元是文档。文档包含一组字段或键值对。考虑这一点的最好方法就是它类似于多维数组。
步骤3:学习基本的实用程序/工具
MongoDB工具和进程主要通过与正在运行的MongoDB实例进行交互操作。这些进程不仅在运行的数据库实例上创建流量,还强制数据库通过内存读取所有数据。以下每种工具都是为了特定目的而设计的,以满足面向文档的数据库中各种功能的需求:
Mongo:这是Mongo的交互式shell,可以让数据库管理员查看、插入、删除和更新数据库中的数据,并获取复制信息,设置分片,关闭服务器,执行JavaScript等等。
Mongostat:一个命令行工具,mongostat显示有关当前正在运行的MongoDB实例状态的统计信息摘要列表。
Mongotop:另一个命令行工具,mongotop提供了一种跟踪MongoDB实例读取和写入数据时间的方法。
Mongoimport,mongoexport:这些命令行实用程序创建Mongo数据库内容的二进制导出。
步骤4:探索主要的特性
MongoDB具有许多重要功能,使其成为接近现代Web应用程序开发时的首选数据库。以下特性代表了该数据库提供的一些主要功能:
支持索引,即席查询和实时聚合。MongoDB通过索引BSON文档和采用唯一的查询语言来支持即席查询。它创建索引以提高搜索的性能。这些特性提供访问和分析数据的强大方法。
支持复制。MongoDB支持两种形式的复制:副本集和主从复制。复制能力非常重要,因为它不断地从主服务器复制数据到辅助服务器。因此,如果主服务器发生故障,则辅助服务器可以接管。
基于哈希的分布。当数据表的不同部分分布在多个服务器上时,此功能适用。它将在所有可用服务器上分发新条目,使数据分布更加均匀。这样做解决了一个主要并常见的问题:缩放。对于大型数据集和高通量操作来说,这一特性尤其重要。
文件存储。此功能称为GridFS,是一个简单的文件抽象。GridFS基本上是一种分解数据库中存储的大型二进制对象的方式。它需要两个查询:一个用于获取文件的元数据,另一个用于获取其内容。因此,如果组织使用GridFS存储小文件,那么其应用程序必须执行的查询数量翻倍。作为一个经验法则,任何一个大到不能马上加载的东西可能不是组织想马上在服务器上加载的东西。因此,组织计划数据流传输的任何内容都是GridFS的一个好选择。
MongoDB管理服务(MMS)。这个功能是一个真正独一无二的产品,因为它代表了一种通常过于复杂的操作的简单方法。现在,通过单击,就可以在单个界面中配置机器和配置副本集并进行升级。
步骤5:进行适当的升级
MongoDB升级到最新的版本是非常重要的,因为旧版本可能会随着时间的推移累积几个安全问题。未能应用更新可能会组织的数据不受保护,并易受黑客攻击。始终安装最新版本,因为这样做将是为组织的文档导向数据库确保更安全的方法。截至2016年12月的最新版本为3.4.1。
MongoDB的入门很容易,但一旦构建应用程序,组织可能会发现会出现更复杂的挑战。避免在开始思考正确的设计,优化和实施之前偏离太远。MongoDB的应用与日俱增,所以在应用之前要清楚地了解基础知识至关重要。