MongoDB固定集合(capped collection)

一 . 什么是固定集合html

MongoDB中有一种特殊类型的集合,值得咱们特别留意,那就是固定集合(capped collection)。算法

固定集合能够声明collection的容量大小,其行为相似于循环队列。数据插入时,新文档会被插入到队列的末尾,若是队列已经被占满,那么最老的文档会被以后插入的文档覆盖。数据库

固定集合特性:固定集合很像环形队列,若是空间不足,最先的文档就会被删除,为新的文档腾出空间。通常来讲,固定集合适用于任何想要自动淘汰过时属性的场景。app

固定集合应用场景ide

好比日志文件,聊天记录,通话信息记录等只需保留最近某段时间内的应用场景,都会使用到MongoDB的固定集合。性能

固定集合的优势日志

1.写入速度提高。固定集合中的数据被顺序写入磁盘上的固定空间,因此,不会由于其余集合的一些随机性的写操做而“中断”,其写入速度很是快(不创建索引,性能更好)。code

2.固定集合会自动覆盖掉最老的文档,所以不须要再配置额外的工做来进行旧文档删除。设置Job进行旧文档的定时删除容易造成性能的压力毛刺。htm

固定集合很是实用与记录日志等场景。教程

二 . 固定集合的建立

不一样于普通集合,固定集合必须在使用前显式建立。

例如,建立固定集合coll_testcapped,大小限制为1024个字节。

db.createCollection("coll_testcapped",{capped:true,size:1024});

除了大小,建立时还能够指定固定集合中文档的数据量。

例如,建立固定集合coll_testcapped,大小限制为1024个字节,文档数量限制为100。

db.createCollection("coll_testcapped2",{capped:true,size:1024,max:100});

建立固定集合还有另外一途径,就是将普通集合装换为固定集合,使用的命令是convertToCapped。

例如将testcol1集合转换为一个大小为1024字节的固定集合:

db.runCommand({"convertToCapped":"testcol1","size":1024})

三 . 固定集合信息的查看

(1)判断集合是否为固定集合,其断定命令为:

db.集合.isCapped() 。

例如判断前面已建立的固定集合coll_testcapped2是否为固定集合:

(2) 从集合信息中获取 有关固定集合的属性,查看集合的指令为:

db.集合.stats()

例如查看集合coll_testcapped2的信息:

四 . 注意事项:

(1) 固定集合建立以后就不能够改变,只能将其删除重建。

(2) 普通集合可使用convertToCapped转换固定集合,可是固定集合不能够转换为普通集合。

(3) 建立固定集合,为固定集合指定文档数量限制时(指参数max),必须同时指定固定集合的大小(指参数size)。无论先达到哪个限制,以后插入的新文档都会把最老的文档移除集合。

(4) 使用convertToCapped命令将普通集合转换固定集合时,既有的索引会丢失,须要手动建立。而且,此转换命令没有限制文档数量的参数(即没有max的参数选项)。

(5) 不能够对 固定集合 进行分片。

(6) 对固定集合中的文档能够进行更新(update)操做,但更新不能致使文档的Size增加或缩小,不然更新失败。

假如集合中有一个key,其value 对应的数据长度为100个字节,若是要更新这个key 对应的value,更新后的值也必须为100个字节,大于100个字节不能够,小于100个字节也不能够。

报错信息为:Cannot change the size of a document in a capped collection : XXXX(XXXX表明某个数据字) !=XXXX。

(7) 不能够对固定集合执行删除文档操做,但能够删除整个集合。

删除文档时,报错信息为:cannot remove from a capped collection:XXXX

(8) 还有必定须要注意,对集合估算size时,不要依据集合的storageSize ,而是依据集合的size。storageSize是wiredTiger存储引擎采用高压缩算法压缩后的。

例如经过db.集合.stats()命令查看某集合的数据,"size" 和 "storageSize" 两者相差仍是很大的。


您可能感兴趣的文章:

文章同步发布: https://www.geek-share.com/detail/2756840364.html

相关文章
相关标签/搜索