MongoDB 的逻辑结构
成都创新互联公司服务项目包括尚志网站建设、尚志网站制作、尚志网页制作以及尚志网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,尚志网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到尚志省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
主要由:文档(document)、集合(collection)和数据库(database)这三部分组成的。
MongoDB的文档(document):mongodb中数据的基本单元,相当于关系数据库中的一行记录,每一个文档都有一个特殊的键"_id",这个键在文档所属的集合中是唯一的。
集合(collection):相当于关系型数据库中的表的概念
文档(document)、集合(collection)、数据库(database)的层次结构如下图:
文档(document) 对应关系型数据中的行(row)
集合(collection) 对应关系型数据中的表(table)
数据库(database) 对应关系型数据中的数据库(database)
MongoDB的数据目录存储所有的MongoDB的数据文件
[mongo@xxxx-xx-xx data]$ ll 总用量 1212436 drwxr-xr-x. 2 mongo dbmon 69 10月 28 17:15 diagnostic.data drwxr-xr-x. 2 mongo dbmon 27 10月 28 15:25 journal -rw-------. 1 mongo dbmon 67108864 10月 28 15:25 local.0 -rw-------. 1 mongo dbmon 1073741824 10月 28 17:15 local.1 -rw-------. 1 mongo dbmon 16777216 10月 28 17:14 local.ns -rw-r--r--. 1 mongo dbmon 6 10月 28 15:17 mongod.lock -rw-r--r--. 1 mongo dbmon 69 10月 28 15:17 storage.bson -rw-------. 1 mongo dbmon 67108864 10月 28 17:00 sykdb.0 -rw-------. 1 mongo dbmon 16777216 10月 28 17:00 sykdb.ns drwxr-xr-x. 2 mongo dbmon 6 10月 28 15:54 _tmp
在MongoDB内部,每个数据库都包含一个.ns 文件和一些数据文件,比如:local.ns,local.0,local.1,随着数据量不断增大,文件的数量也会不断地增多。
每张表都对应一个命名空间,每个索引也有对应的命名空间。而这些命名空间的元数据都放在*.ns 文件中。
MongoDB内部有预分配空间的机制,预分配的文件都用0进行填充,这样mongodb始终保持额外的空间和空余的数据文件。数据文件每次新生成的一个文件,它的大小都会是上一个数据文件大小的2倍。比如我的local.0是67108864,local.1就是1073741824
参考:mongodb系列-体系结构