Capped Collections
Capped collections 就是固定大小的collection。
它有很高的性能以及队列过期的特性(过期按照插入的顺序). 有点和 "RRD" 概念类似。
Capped collections是高性能自动的维护对象的插入顺序。它非常适合类似记录日志的功能。
创建一个 Capped Collection
和标准的collection不同,你必须要显式的创建一个capped collection,
指定一个collection的大小,单位是字节。collection的数据存储空间值提前分配的。
要注意的是指定的存储大小包含了数据库的头信息。
> db.createCollection("mycoll", {capped:true, size:100000}) 使用和约束
特性
应用
建议
限制对象的个数你可能也需要限定collection中对象的数量。如果到了限制的数量,就要移除一个最近的插入。 限制对象的数量, 指定 max参数。 注意: 当指定了对象的数量,你也必须要限制存储大小。 要确定的是存储大小要完全能够存储限制的对象数, 不然的话,移除对象速度会加快。你可以使用validate()工具来查看collection使用的存储空间, 这样就可以预估需要的空间。 注意: 只限制存储大小性能要更好一些。 db.createCollection("mycoll", {capped:true, size:100000, max:100}); db.mycoll.validate(); 提示: 当编程的时候,存储最近对象的版本号的方法就是把max参数设为1(max=1)。 预分配普通的collectioncreateCollection 命令也可以用于不是capped collections。如 db.createCollection("mycoll", {size:10000000});
db.createCollection("mycoll", {size:10000000, autoIndexId:false}); 通过createCollection来显式创建一个非capped collection允许指定一些参数。 如,指定collection大小,来预分配collection所需的硬盘空间。 autoIndexId 字段可以指定是否要在_id创建唯一索引。默认的情况下, 非capped collection要在_id上创建索引。
ShardingCapped collections 还不支持数据切分 查看一个collection是否为capped collection你可以调用isCapped方法来查看一个collection是否为capped collection。 db.foo.isCapped() |