• 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或者更高版本。
  • 相关阅读:
    全选和选项交互
    无法将类型为excel.applicationclass的com 强制转换为接口类型的解决方法[转]
    SilverLight搭建WCF聊天室详细过程[转]
    进程与线程的一个简单解释
    Visiual Studio CLR20r3
    C#注册表操作类--完整优化版
    cmd注册外部命令
    C# Dsofile.dll无法注册运行问题解决
    .net版,微信免充值代金卷业务开通验收代码
    C#十进制与任意进制的转换
  • 原文地址:https://www.cnblogs.com/xinghebuluo/p/2332220.html
Copyright © 2020-2023  润新知