在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

MongoDB中固定集合capped collection的示例分析

105次阅读
没有评论

共计 1941 个字符,预计需要花费 5 分钟才能阅读完成。

这篇文章将为大家详细讲解有关 MongoDB 中固定集合 capped collection 的示例分析,丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一 . 什么是固定集合

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

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

固定集合特性:固定集合很像环形队列,如果空间不足,最早的文档就会被删除,为新的文档腾出空间。一般来说,固定集合适用于任何想要自动淘汰过期属性的场景。

固定集合应用场景

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

固定集合的优点

1. 写入速度提升。固定集合中的数据被顺序写入磁盘上的固定空间,所以,不会因为其他集合的一些随机性的写操作而“中断”,其写入速度非常快(不建立索引,性能更好)。

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

固定集合非常实用与记录日志等场景。

二 . 固定集合的创建

不同于普通集合,固定集合必须在使用前显式创建。

例如,创建固定集合 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 二者相差还是很大的。

关于“MongoDB 中固定集合 capped collection 的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-03发表,共计1941字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 香蕉视频一区二区三区 | 亚洲大码熟女在线观看 | 性生一级| 不卡中文字幕在线观看 | 视频一区二区精品的福利 | 色av综合av综合无码网站 | 亚洲欧美日韩综合二区三区 | 久久精品福利视频在线观看 | 囯产精品一区二区三区线 | 国产原创麻豆 | 性色av一区二区三区咪爱四虎 | 国产网友自拍视频 | 一级爱做片免费观看久久 | 日韩精品亚洲专区在线影视 | 四虎在线观看网址 | 亚洲国产精品一区二区久 | 亚洲欧美另类激情综合区蜜芽 | 一二区 | 一本一本久久a久久精品综合 | 青免费视频 | 国产精品欧美韩国日本久久 | 亚洲网址在线观看 | 麻豆黄色仓库 | 亚洲人成电影在线观看天堂色 | 成人无码免费一区二区三区 | 日韩成人精品日本亚洲 | 色老头福利视频在线观看 | 久久乐国产精品亚洲综合18 | 日韩插啊免费视频在线观看 | 中文字幕av无码一区二区三区 | 无码av专区丝袜专区 | 最近最好的中文字幕2019免费 | 国产卡一卡二卡三 | 久久精品国产久精国产爱 | 熟妇人妻无乱码中文字幕真矢织江 | 国产精品麻豆a在线播放 | 亚洲毛片无码专区亚洲乱 | 三年片在线观看免费观看大全中国 | 91专区在线观看 | 免费毛片在线看片免费丝瓜视频 | 在线观看日韩一区 |