MongoDB管理与开发精要《红丸出品》3.2 数据存储结构

----------------------------------------------------------------------------------------------------------------
《MongoDB管理与开发精要》、《Redis实战》作者
@CD红丸                    http://weibo.com/u/2446082491
----------------------------------------------------------------------------------------------------------------
3.2 数据存储结构

MongoDB对国内用户来说比较新,它就像是一个黑盒子,但是如果对于它内部的数据存储了解多一些的话,那么将会很快的理解和驾驭MongoDB,让它发挥它更大的作用。

 

MongoDB的默认数据目录是/data/db,它负责存储所有的MongoDB的数据文件。在MongoDB内部,每个数据库都包含一个.ns文件和一些数据文件,而且这些数据文件会随着数据量的增加而变得越来越多。所以如果系统中有一个叫做foo的数据库,那么构成foo这个数据库的文件就会由foo.nsfoo.0foo.1foo.2等等组成,具体如下:

[root@localhost db]# ll /data/db/

总计 196844

-rw------- 1 root root 16777216 04-15 16:33 admin.0

-rw------- 1 root root 33554432 04-15 16:33 admin.1

-rw------- 1 root root 16777216 04-15 16:33 admin.ns

-rw------- 1 root root 16777216 04-21 17:30 foo.0

-rw------- 1 root root 33554432 04-21 17:30 foo.1

-rw------- 1 root root 67108864 04-21 17:30 foo.2

-rw------- 1 root root 16777216 04-21 17:30 foo.ns

-rwxr-xr-x 1 root root        6 04-21 17:16 mongod.lock

-rw------- 1 root root 16777216 04-15 16:30 test.0

-rw------- 1 root root 33554432 04-15 16:30 test.1

-rw------- 1 root root 16777216 04-15 16:30 test.ns

drwxr-xr-x 2 root root     4096 04-21 17:30 _tmp

 

MongoDB内部有预分配空间的机制,每个预分配的文件都用0进行填充,由于有了这个机制, MongoDB始终保持额外的空间和空余的数据文件,从而有效避免了由于数据暴增而带来的磁盘压力过大的问题。

 

由于表中数据量的增加,数据文件每新分配一次,它的大小都会是上一个数据文件大小的2倍,每个数据文件最大2G。这样的机制有利于防止较小的数据库浪费过多的磁盘空间,同时又能保证较大的数据库有相应的预留空间使用。

 

数据库的每张表都对应一个命名空间,每个索引也有对应的命名空间。这些命名空间的元数据都集中在*.ns文件中。

 

在下图中,foo这个数据库包含3个文件用于存储表和索引数据,foo.2文件属于预分配的空文件。foo.0foo.1这两个数据文件被分为了相应的盘区对应不同的名字空间。

上图显示了命名空间和盘区的关系。每个命名空间可以包含多个不同的盘区,这些盘区并不是连续的。与数据文件的增长相同,每一个命名空间对应的盘区大小的也是随着分配的次数不断增长的。这样做的目的是为了平衡命名空间浪费的空间与保持某一个命名空间中数据的连续性。上图中还有一个需要注意的命名空间:$freelist,这个命名空间用于记录不再使用的盘区(被删除的Collection或索引)。每当命名空间需要分配新的盘区的时候,都会先查看$freelist是否有大小合适的盘区可以使用,这样就回收空闲的磁盘空间。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. MongoDB安装与配置 步骤如下: 1. 下载MongoDB: 在MongoDB官网 https://www.mongodb.com/ 中下载相应的版本。 2. 安装MongoDB: 运行下载后的安装程序,按照提示进行安装。 3. 配置MongoDB: 打开MongoDB安装目录下的bin文件夹,找到mongod.exe文件,将其添加到系统环境变量中,然后在命令行中输入mongod,启动MongoDB。 4. 测试MongoDB: 在命令行中输入mongo,连接MongoDB数据库。 2. MongoDB数据操作 MongoDB数据操作主要包括增删改查四个方面,具体操作如下: 1. 插入数据:使用insert()方法插入数据,语法如下: db.collection.insert(document) 其中,db.collection是集合名称,document是要插入的数据。 2. 删除数据:使用remove()方法删除数据,语法如下: db.collection.remove(query) 其中,db.collection是集合名称,query是删除条件。 3. 更新数据:使用update()方法更新数据,语法如下: db.collection.update(query,update,options) 其中,db.collection是集合名称,query是更新条件,update是更新内容,options是更新选项。 4. 查询数据:使用find()方法查询数据,语法如下: db.collection.find(query) 其中,db.collection是集合名称,query是查询条件。 3. Java使用MongoDB Java中使用MongoDB需要引入MongoDB驱动程序,然后通过Java代码操作MongoDB数据库。 步骤如下: 1. 引入MongoDB驱动程序:在Java项目中引入MongoDB驱动程序,可以通过Maven或手动下载并添加到项目中。 2. 连接MongoDB:使用MongoClient类连接MongoDB数据库,语法如下: MongoClient mongoClient = new MongoClient("localhost", 27017); 其中,localhost是MongoDB数据库所在的主机名,27017是MongoDB数据库所使用的端口号。 3. 获取MongoDB数据库:使用getDatabase()方法获取MongoDB数据库,语法如下: MongoDatabase mongoDatabase = mongoClient.getDatabase("test"); 其中,test是MongoDB数据库的名称。 4. 获取MongoDB集合:使用getCollection()方法获取MongoDB集合,语法如下: MongoCollection<Document> collection = mongoDatabase.getCollection("users"); 其中,users是MongoDB集合的名称。 5. 插入数据:使用insertOne()方法插入数据,语法如下: Document document = new Document("name", "Tom").append("age", 18); collection.insertOne(document); 其中,name和age是数据的字段名,"Tom"和18是数据的值。 6. 删除数据:使用deleteOne()方法删除数据,语法如下: collection.deleteOne(Filters.eq("name", "Tom")); 其中,name是数据的字段名,"Tom"是数据的值。 7. 更新数据:使用updateOne()方法更新数据,语法如下: collection.updateOne(Filters.eq("name", "Tom"), new Document("$set", new Document("age", 20))); 其中,name是数据的字段名,"Tom"是数据的值,$set是更新操作符,age是更新后的值。 8. 查询数据:使用find()方法查询数据,语法如下: MongoCursor<Document> cursor = collection.find().iterator(); while (cursor.hasNext()) { Document document = cursor.next(); System.out.println(document); } 其中,find()方法可以不带参数,表示查询所有数据。查询结果会返回一个游标,可以通过循环遍历游标获取查询结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值