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

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  
写的很好啊,学习了

相关推荐

    drop-mongodb-collections:删除所有(非系统)mongodb 集合

    drop-mongodb-collections 删除所有非系统 mongodb 集合。 用于测试。用法 > npm i drop-mongodb-collections --save-dev const dropMongoDbCollections = require ( 'drop-mongodb-collections' ) ( 'mongodb://...

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

    mongodb数据如何还原,同步到其他系统?只要我们了解了数据库日志原理,一切都是那么简单 oplog原理 ...Capped collections的特点是高效插入和检索,所以最好不要在Capped collections上添加额外的索

    基于MongoDB的日志系统Mongodb-Log.zip

    MongoDB 的 Capped Collection是一个天生的日志系统,MongoDB自己的oplog就是用它来存储的,Capped Collection的特点是可以指定Collection的大小,当记录总大小超过设定大小后,老的数据会被自动抹掉用于存储新的...

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

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

    MongoDB固定集合(capped collection)的知识小结

    MongoDB中有一种特殊类型的集合,值得我们特别留意,那就是固定集合(capped collection)。 固定集合可以声明collection的容量大小,其行为类似于循环队列。数据插入时,新文档会被插入到队列的末尾,如果队列已经...

    Linux安装mongodb客户端

    sudo vim /etc/yum.repos.d/mongodb-org-4.2.repo 写入: [mongodb-org-4.2] name=MongoDB Repository baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.2/x86_64/ gpgcheck=1 enabled=1 gpg...

    MongoDB应用设计模式

    资源名称:MongoDB应用设计模式内容简介:无论是在构建社交媒体网站,还是在开发一个仅在内部使用的企业应用程序,《MongoDB应用设计模式》展示了MongoDB需要解决的商业问题之间的连接。你将学到如何把MongoDB设计...

    MongoDB笔记.docx

    一、MongoDB简介 3 二、MongoDB结构 3 二、MongoDB 数据库关系型(这里并不是值关系型数据库的关系) 3 1、MongoDB一对一关系型 3 2、MongoDB一对多关系型 4 3、MongoDB多对多关系型 4 三、创建数据库(mongodb_test...

    如何安装MongoDB 如何使用MongoDB

    本课程是一套关于MongoDB应用开发的实战性教程,名为《深入浅出MongoDB应用实战开发(基础、开发指南、系统管理、集群及系统架构)》,教程侧重于讲解MongoDB的常用特性及高级特性,从实际开发的角度出发对MongoDB...

    mongodb-linux-x86_64-4.0.18.tgz

    mv mongodb-linux-x86_64-4.0.18 mongodb 3、进入 mongodb 目录创建目录 db 和 logs cd /usr/local/mongodb mkdir db mkdir logs 4、进入到 bin 目录下,编辑 mongodb.conf 文件,内容如下: dbpath=/usr/local/...

    【BAT必备】MongoDB面试题

    【BAT必备】MongoDB面试题【BAT必备】MongoDB面试题【BAT必备】MongoDB面试题【BAT必备】MongoDB面试题【BAT必备】MongoDB面试题【BAT必备】MongoDB面试题【BAT必备】MongoDB面试题【BAT必备】MongoDB面试题【BAT...

    MongoDB图形化管理工具 MongoDB Compass

    MongoDB图形化管理工具 MongoDB Compass

    MongoDB(mongodb-org-server_5.0.4_amd64.deb)

    MongoDB Community Server(mongodb-org-server_5.0.4_amd64.deb)适用于适用于Debian10 MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。 MongoDB是...

    五、MongoDB 学习PPT

    MongoDB 学习PPT

    MongoDB4.2分片及副本集群搭建

    MongoDB4.2分片及副本集群搭建 MongoDB集群 MongoDB分片 MongoDB副本 MongoDB副本集群

    MongoDB(mongodb-src-r5.0.4.tar.gz)

    MongoDB Community Server(mongodb-src-r5.0.4.tar.gz)源代码 MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。 MongoDB是一个介于关系数据库和非...

    MongoDB教程基础入门

    教程名称:MongoDB教程基础入门 课程目录:【】MongoDB教程基础入门-代码【】MongoDB教程基础入门01第一讲上【】MongoDB教程基础入门02第一讲下【】MongoDB教程基础入门03第二讲上【】MongoDB教程基础入门04第二讲...

    MongoDB Community(mongodb-linux-aarch64-ubuntu1804-5.0.8.tgz)

    MongoDB Community Server(mongodb-linux-aarch64-ubuntu1804-5.0.8.tgz)适用于Ubuntu 18.04 Arm芯片, MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决...

    mongodb c#驱动最新驱动mongodb.driver.dll 版本2.12.0-beta1

    mongodb c#驱动 最新驱动mongodb.driver.dll 版本2.12.0-beta1,包内有MongoDB.Bson.dll 、mongodb.driver.core.dll 等文件

    mongodb-v4.0

    mongodb-win32-x86_64-2008plus-ssl-v4.0-latest-signed.msi

Global site tag (gtag.js) - Google Analytics