`
风雪涟漪
  • 浏览: 508661 次
  • 性别: Icon_minigender_1
  • 来自: 大连->北京
博客专栏
952ab666-b589-3ca9-8be6-3772bb8d36d4
搜索引擎基础(Search...
浏览量:9069
Ae468720-c1b2-3218-bad0-65e2f3d5477e
SEO策略
浏览量:18482
社区版块
存档分类
最新评论

MongoDB Capped Collections

阅读更多

Capped Collections

Capped collections 就是固定大小的collection。
它有很高的性能以及队列过期的特性(过期按照插入的顺序). 有点和 "RRD" 概念类似。

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

 

创建一个 Capped Collection

和标准的collection不同,你必须要显式的创建一个capped collection,
指定一个collection的大小,单位是字节。collection的数据存储空间值提前分配的。
要注意的是指定的存储大小包含了数据库的头信息。

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

使用和约束

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

特性

  • 如果空间都被使用完毕,新添加的对象会取代最旧的那个数据。
  • 如果你执行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("mycoll", {capped:true, size:100000, max:100});
db.mycoll.validate();

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

预分配普通的collection

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

db.createCollection("mycoll", {size:10000000});
db.createCollection("mycoll", {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()

分享到:
评论
1 楼 di1984HIT 2013-07-11  
写的很好啊,学习了

相关推荐

    mongodb3.2.8入门到精通视频教程.zip

    3.Capped Collections介绍及生产环境之疲劳度过滤,日志应用 4.Bson结构解析以及$type和_id原理详细分析 5.mongodb shell使用loadjs与mongodb高速交互分析 6.高频咨询之sql statement 和mongodb statement对照分析和...

    MongoDB文档与集合.pdf

    MongoDB 还提供了一种特殊的集合类型——“固定大小集合”(Capped Collections),用于实现高性能的队列功能。Capped Collections 有固定的存储容量,一旦达到上限,新插入的数据会替换最旧的数据,保持集合的大小...

    MongoDB性能调优

    Capped Collections 是高效率的 Collection 类型,它有如下特点:固定大小;可以 insert 和 update 操作;不能 delete 操作;默认基于 Insert 的次序排序的。 Server Side Code Execution Server-Side Processing ...

    mongodb优化

    4. 使用 capped collection:对于固定大小且需要保持插入顺序的数据,capped collections 是理想选择。 5. 服务器端代码执行:使用聚合框架(aggregation pipeline)在服务器端处理复杂逻辑,减少网络传输。 6. 强制...

    java的mongodb客户端

    固定集合(Capped Collections): 固定集合是一种特殊的集合,其大小是固定的,一旦达到最大大小,新的插入将覆盖旧的数据。创建固定集合的代码如下: ```java List<IndexModel> indexes = Arrays.asList( new ...

    30分钟学MongoDB系列——限定集与大文件存储篇

    本次讨论的是MongoDB中的限定集(Capped Collections)和大文件存储(GridFS)两个特色功能。 首先,限定集是MongoDB中一种特殊的集合类型,它有一个固定大小的存储空间,当数据存储超过这个空间限制时,新插入的...

    MongoDB 学习文档,内附Java代码

    - `show collections`列出当前数据库中所有的集合。 - **创建集合**: - 使用`db.createCollection("collection_name")`命令创建集合。 - 如果需要创建固定大小的集合(即capped collection),可以使用以下格式: ...

    MongoDB

    7. **Capped Collections**:这种特殊的集合限制了大小,一旦达到上限,新插入的数据会覆盖旧数据,适用于日志记录和时间序列数据。 8. **地理空间索引**:MongoDB内置了地理空间索引,能够快速地执行地理位置相关...

    mongodb基本命令和实例

    在某个数据库下,`show collections` 命令用于显示该数据库中的所有集合(collections),这些是MongoDB中存储数据的基本单元。 4. **查看服务器状态**: `db.serverStatus()` 提供了关于MongoDB服务器的详细信息...

    MongoDB权威指南.pdf

    5. ** capped collections**: 限制大小的集合,用于实现日志记录或消息队列功能,一旦达到上限,新数据会覆盖旧数据。 6. **GridFS**: 用于存储大型文件,将文件拆分为多个小块存储在MongoDB中。 五、MongoDB与其他...

    mongodb常用命令大全

    ### MongoDB常用命令详解 #### 一、数据库管理 在MongoDB中,数据库是存储文档的容器,通过一系列的命令可以方便地对数据库进行管理和操作。 ##### 1. 帮助命令 (Help) - **命令格式**: `help`, `db.help()`, `db...

    MongoDB固定集合.pdf

    MongoDB的固定集合(Capped Collections)是一种特殊类型的集合,设计用于高效地存储有固定大小限制的数据,类似于一个循环缓冲区。固定集合的主要特点是它的大小是固定的,一旦达到上限,新的插入操作会覆盖最早的...

    详解MongoDB管理命令

    6. `db.createCollection(name, options)`:创建一个新的集合,可以设置大小限制(capped)或最大文档数量。 7. `db.collection.find()` 和 `db.collection.find(filter)`:查询集合中的文档,filter 可以用来过滤...

    mongodb学习资料.doc

    - 可以设置上限(capped)和大小(size),例如`db.createCollection("stu",{capped:true,size:10})`。 - 不手动创建集合也没问题,MongoDB会自动创建当你插入第一条数据时。 2. **显示集合**: - `show ...

    详解MongoDB数据还原及同步解决思路

    - Capped collections(固定大小的集合)用于存储Oplog,其特性决定了它是FIFO(先进先出)的,因此旧的记录会被新记录覆盖。 - Oplog不支持在文档内部增加字段,只能替换或删除已有字段,这是为了保证插入性能和...

    MongoDB性能优化

    - **定义**:Capped Collections是一种特殊的集合类型,具有固定大小,并按照插入顺序存储数据。当集合达到最大容量时,新插入的数据会覆盖最早的记录。 - **特性**: - 固定大小:创建时需指定大小。 - 插入和...

    MongoDB的介绍和使用.docx

    3. 查看表:`show tables` 或 `show collections` 4. 删除表:`db.user.drop()` 5. 删除数据库:`db.dropDatabase()` 6. 删除数据:`db.user.remove({name:'gdh'})` 创建表 1. 语法:`db.createCollection(name, ...

Global site tag (gtag.js) - Google Analytics