MongoDB1.8RC0版本的特性有哪些-创新互联

本篇文章给大家分享的是有关MongoDB 1.8 RC0版本的特性有哪些,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

公司主营业务:成都网站建设、网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。成都创新互联公司是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。成都创新互联公司推出安平免费做网站回馈大家。

前两天MongoDB发布了1.8版本,看到的大多数描述都是说到增加了Journaling日志文档这个改进。

MongoDB1.8RC0版本有哪些特性

1.Journaling日志文档增加单机可靠性

好吧,Journaling其实就是日志的意思,这里暂且当一个名词用吧。它的使用方法是在启动时加上–dur选项。Journaling的出现应该归因于前段时间发生的某用户在单机使用MongoDB然后进行了kill-9操作导致数据不可用后提出的。关于这个事件的描述可以看这里。

Journaling不仅能增强系统的可靠性,对于非正常关闭的MongoDB的重启方式也有改变,从原来的需要进行漫长的repair操作,改成了进行在现在数据文件上重新执行Journaling日志记录的操作。速度可以得到很大的提升。当然,如果是一次正常关闭,那么所有的Journaling日志就没用了,会被直接清除掉。

Journaling日志的GroupCommits机制

Journaling日志支持GroupCommits功能,就是将一段时间的日志文件合起来进行一次磁盘写操作。在1.8版本里,它的提交时间间隔大概是100ms。

Journaling对fsync操作的影响

如果使用了–dur参数启动MongoDB,那么在执行fsync命令时,将不会是对所有数据文件进行fsync操作后返回,而是在Journaling日志写到磁盘上就返回。

2.SparseIndex和CoveredIndex

SparseIndex只能对一个列进行索引,这一限制带来的好处是,它不会对该项值为空的行作索引。这样就大大减小了某些列的索引大小。比如你在文章列表中建立了一个是否删除的标识,删除掉的文章这个值为1,其它文章没有这个值,那么在对这个值建立的索引就会非常小。

SparseIndex的使用示例如下,只需要在第二个参数加上sparse为true的标识即可:

db.people.ensureIndex({title:1},{sparse:true})

CoveredIndex是在联合索引中,如果你查找的值正好是在索引中,则可以直接返回索引中存的值,而不用到数据文件中查找。(这个在传统关系型数据库中也有实现)

MongoDB1.8RC0版本有哪些特性

3.Map/Reduce输出模式可配置

在1.8版本中,MongoDB的Map/Reduce不再将结果输出到某个collection中,而是让用户在跳Map/Reduce任务时指定用何种方式输出,下面是四种方式,使用方法是在Map/Reduce命令加上out参数,例:

db.users.mapReduce(map,reduce,{out:{inline:1}});

下面是四种方式:

“collectionName”–如果设置out为一个collection名,那么输出结果将会存在这个collection中,这个collection如果本来就存在,那么数据将会被抹掉。

{merge:“collectionName”}-这个选项和上面的略有不同,不同在于数据不会被全部分抹掉,只是覆盖掉与Map/Reduce结果有索引冲突的项。

{reduce:“collectionName”}–此选项比上一个选项又复杂一点,此选项在上面的情况下不会覆盖掉原来的数据,而是选择调用reduce方法和finalize方法(如果指定了的话)来合并重复的项。

{inline:1}-当指定这个选项时,结果不会存在某一个collection里,而是直接输出一个数据对象,需要注意的是,只有当结果数据小于8M时才适用。

以上就是MongoDB 1.8 RC0版本的特性有哪些,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注创新互联行业资讯频道。

名称栏目:MongoDB1.8RC0版本的特性有哪些-创新互联
文章起源:https://www.cdcxhl.com/article36/digppg.html

成都网站建设公司_创新互联,为您提供响应式网站品牌网站建设网站改版网页设计公司企业建站电子商务

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

网站建设网站维护公司