• mongodb指南(翻译)(二十一) developer zone 索引(五)在后台创建索引


    默认情况下,ensureIndex()是阻塞型操作,并会暂停数据库上所有正在进行的其他操作,直到创建索引完成。但是,在高于或等于版本1.3.2的mongodb中,提供了可选的后台创建索引的选项。

    要在后台创建索引,增加background:true选项。例如:

    > db.things.ensureIndex({x:1}, {background:true});
    > db.things.ensureIndex({name:1}, {background:true, unique:true,
    ... dropDups:true});

    当后台模式启动时,其他的操作,包含写,在创建索引期间不会被阻塞。该索引在创建完成前不会被应用到查询中去。

    尽管该操作是“后台”类型意味着其他操作可以并发执行,但是该命令在创建完成前不会立即返回到shell提示符。要同时执行其他操作,可以另外打开一个mongo shell实例。

    需要注意的是,后台模式创建索引是新增加的方法,它比默认的前端模式要慢:需要更多的时间来创建索引。

    在创建索引过程中,可以通过db.currentOp()命令查看到该操作依旧在进行中(显示为对system.indexes的插入操作)。你可以使用db.killOp()来终止创建过程。

    在创建索引过程中,该索引在system.indexes中是可见的,但是创建完成前它不会被用到查询操作中。

    注意:

    • 每个集合在同一时刻只允许创建一个索引。
    • 一些管理操作,如repairDatabase,不允许在后台创建索引期间使用。
    • (应用到生产环境,应使用)v1.4或者更高版本。
  • 相关阅读:
    e807. 设置进程监听对话框的延迟弹出
    e806. 创建进程监听对话框
    Spring MVC静态资源处理
    SpringMVC处理方法的数据绑定
    HttpMessageConverter
    Redis中对Key进行分类
    LinkedHashMap源码剖析
    TreeMap源代码深入剖析
    CMS垃圾收集器
    @Java VisualVM 插件地址
  • 原文地址:https://www.cnblogs.com/xinghebuluo/p/2332220.html
Copyright © 2020-2023  润新知