码迷,mamicode.com
首页 > 数据库 > 详细

mongodb的体系

时间:2016-10-29 02:36:44      阅读:351      评论:0      收藏:0      [点我收藏+]

标签:document   collection   mongodb   

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系列-体系结构 


本文出自 “刚刚出壳的小鸟” 博客,请务必保留此出处http://qhd2004.blog.51cto.com/629417/1866883

mongodb的体系

标签:document   collection   mongodb   

原文地址:http://qhd2004.blog.51cto.com/629417/1866883

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!