MongoDB 固定集合(Capped Collections)

本文深入探讨MongoDB中的Capped Collections,一种固定大小且自动维护插入顺序的集合类型,适用于日志记录、缓存和自动存档等场景。文章详细讲解了Capped Collections的创建、使用限制、特性和应用案例。

refs:

1)Capped Collections | MongoDB Blog

2)https://xiayuanfeng.iteye.com/blog/989024

3)MongoDB 固定集合(Capped Collections) | 菜鸟教程

4)Capped Collections — MongoDB Manual

Capped Collections

固定大小的集合

Capped collections 就是固定大小的collection。

它有很高的性能以及队列过期的特性(过期按照插入的顺序). 有点和 "RRD" 概念类似。

Capped collections是高性能自动的维护对象的插入顺序。它非常适合类似记录日志的功能。

固定集合的一些限制,无法删除或更新文档(文档不能增长)。

创建一个 Capped Collection

和标准的collection不同,你必须要显式的创建一个capped collection,

指定一个collection的大小,单位是字节。collection的数据存储空间值提前分配的。

要注意的是指定的存储大小包含了数据库的头信息。

> db.createCollection("myLogCollection", {capped:true, size:100000})

如果size 小于等于4096,那集合固定为 4096 bytes大小。否则MongoDB会使得size始终为256的整数倍。

另外可以用 max 指定集合最大的文档数。

db.createCollection("myLogCollection", { capped : true, size : 5242880, max : 5000 } )

size 参数是必须的,而且size的优先级比max高。如果先达到size大小,而没有达到max的文档数,是会按size移除旧的文档的。

 

 

 

size 是整个集合空间大小,单位为【字节】

max 是集合文档个数上线,单位是【个】

如果空间大小到达上限,则插入下一个文档时,会覆盖第一个文档;如果文档个数到达上限,同样插入下一个文档时,会覆盖第一个文档。两个参数上限判断取的是【与】的逻辑。

将已存在的集合转换为固定集合可以使用以下命令:

>db.runCommand({"convertToCapped":"myLogCollection",size:10000})

以上代码将我们已存在的 posts 集合转换为固定集合。

查看当前db占用空间

>db.stats()
{
	"db" : "test",
	"collections" : 5,
	"views" : 0,
	"objects" : 53829,
	"avgObjSize" : 43.555,
	"dataSize" : 2344556121,
	"storageSize" :3124416336,
	"numExtents" : 0,
	"indexes" : 7,
	"indexSize" : 8096876,
	"ok" : 1
}

collection查看

使用和约束

  • 在capped collection中,你能添加新的对象。
  • 能进行更新,然而,对象不会增加存储空间。如果增加,更新就会失败 。
  • 数据库不允许进行删除。使用drop()方法删除collection所有的行。
    注意: 删除之后,你必须显式的重新创建这个collection。
  • 在32bit机器中,capped collection最大存储为1e9个字节(最大值约为482.5M),64位上只受系统文件大小的限制。

特性

  • 如果空间都被使用完毕,新添加的对象会取代最旧的那个数据。
  • 如果你执行find(),并没有指定顺序。返回的结果就是按照插入顺序排序。  
  • 倒序使用 find().sort({$natural:-1})。

应用

  • 日志Logging. Capped collection性能非常优秀,可以来存储日志文档。
  • 插入一个没有索引的capped collection速度非常接近存储在文件系统。
  •  额外的忧郁使用了内置的LRU机制,也不用担心超出硬盘空间。
  • 缓存Caching. 如果你希望在数据库缓存一些小数量的对象。
  • capped collection提供了非常方便的机制来实现这个操作。
  • 注意的是要给capped table添加索引,因为这种应用,读频率高于写。
  • 自动存档Auto Archiving. 如果你希望数据自动过期。
  • capped collection要比手写cron scripts更为方便。

建议

  • 为了最大化性能,不要再capped collection上创建索引。
  • 如果这个collection写操作多于读操作,更不需要索引了。
  • 注意的是,你可能创建了索引。速度就会降低,但是还是要比标准的collection要快。
  • 使用 natural ordering 来更有效的获取最近插入的元素。和linux的tail命令相似。

限制对象的个数

你可能也需要限定collection中对象的数量。如果到了限制的数量,就要移除一个最近的插入。

限制对象的数量, 指定 max参数。

注意: 当指定了对象的数量,你也必须要限制存储大小。

要确定的是存储大小要完全能够存储限制的对象数,

不然的话,移除对象速度会加快。你可以使用validate()工具来查看collection使用的存储空间,

这样就可以预估需要的空间。

注意: 只限制存储大小性能要更好一些。

db.createCollection("myLogCollection", {capped:true, size:100000, max:100});
db.mycoll.validate();

提示: 当编程的时候,存储最近对象的版本号的方法就是把max参数设为1(max=1)。

预分配普通的collection

createCollection 命令也可以用于不是capped collections。如

db.createCollection("myLogCollection", {size:10000000});
db.createCollection("myLogCollection", {size:10000000, autoIndexId:false});

通过createCollection来显式创建一个非capped collection允许指定一些参数。

如,指定collection大小,来预分配collection所需的硬盘空间。 

 autoIndexId 字段可以指定是否要在_id创建唯一索引。默认的情况下,

非capped collection要在_id上创建索引。

默认的情况下,capped collection不会在_id添加索引。

Sharding

Capped collections 还不支持数据切分

查看一个collection是否为capped collection

你可以调用isCapped方法来查看一个collection是否为capped collection。 db.foo.isCapped()

<think>好的,用户想学习如何在MongoDB中创建集合。首先,我需要整理MongoDB中创建集合的两种主要方法:自动创建和手动使用`db.createCollection()`命令。根据提供的引用内容,引用[1]提到插入文档时会自动创建集合,而引用[3]和引用[4]则展示了手动创建的方式。需要明确这两种方法的区别和使用场景。 接下来,要确保步骤清晰。自动创建非常简单,用户只需插入文档即可,如引用[1]中的示例`db.mycol2.insert({"name" : "菜鸟教程"})`。手动创建则允许更多的配置选项,比如设置集合的大小、是否固定等,这在引用[3]和引用[4]中都有提到,例如`db.createCollection("liulianjiangcsdn")`和带有参数的创建方式。 还需要注意用户可能遇到的常见问题,比如集合命名规则、何时选择手动创建等。例如,当需要特定配置如固定集合capped)时,必须手动创建。同时,要提醒用户使用`show collections`来验证集合是否创建成功,这在引用[1]和引用[3]中都有示例。 然后,根据用户的要求生成相关问题。问题应涵盖创建方法、配置选项、应用场景以及常见错误,这样用户能进一步深入学习。需要确保问题与引用内容相关,比如引用[4]提到的参数配置,可以生成关于参数的问题。 最后,检查回答是否符合格式要求,如使用正确的LaTeX格式,避免使用Markdown,结构清晰,分步骤说明,并正确添加引用标识。确保没有遗漏任何关键点,并且引用来源准确对应。</think>### MongoDB 创建集合教程 在MongoDB中,创建集合主要有两种方式:**自动隐式创建**和**手动显式创建**。以下为具体方法及步骤: --- #### 1. 自动隐式创建集合 当向一个**不存在的集合**插入文档时,MongoDB会自动创建该集合。 **操作示例**: ```javascript > use test // 切换到test数据库 > db.my_new_collection.insert({name: "示例数据", value: 100}) // 插入文档时自动创建集合 ``` 插入成功后可通过 `show collections` 验证集合是否存在[^1][^3]。 --- #### 2. 手动显式创建集合 使用 `db.createCollection(name, options)` 命令可自定义集合属性,适用于需要特殊配置的场景。 **语法参数**: - `name`: 集合名称 - `options`(可选): 包含配置项的对象,如: - `capped`: 是否创建固定集合固定大小,数据覆盖写入)[^4] - `size`: 固定集合的存储上限(单位:字节) - `max`: 固定集合允许的最大文档数 **操作示例**: ```javascript > db.createCollection("logs", { capped: true, size: 1048576 }) // 创建1MB大小的固定集合 > db.createCollection("users") // 创建普通集合 ``` 创建后可通过 `db.getCollectionInfos({name: "logs"})` 查看集合详细信息[^3]。 --- #### 关键区别与使用场景 | 方法 | 适用场景 | 特点 | |--------------|--------------------------------------|--------------------------| | 自动隐式创建 | 快速插入数据,无需特殊配置 | 简单但无法设置集合属性 | | 手动显式创建 | 需要固定大小、索引优化等高级配置时 | 灵活性高,可定制参数 | ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值