0

我目前正在从 couchdb 迁移到 mongodb,仍在学习这些东西,并且每当我在网页中进行一些排序查询时都会遇到问题。我使用 codeigniter 作为框架,并使用alexbilbie lib for mongodb php library。

所以,这是我的问题:我打算从房间中的传感器进行查询,每秒更新一次(因此,已经保存了数千个文档)并获取每个最新的传感器值,我使用来自模型的查询:

function mongoGetDocLatestDoc($sensorid){
    $doc = $this->mongo_db->where(array('SensorId'=>$sensorid))->limit(1)->order_by(array('_id'=>'DESC'))->get('my_mongo');
    return $doc;

}

如果我用我的控制器调用它,处理查询会花费大量时间,如果我更改时间戳排序,情况会更糟。每次我为第二个传感器再次调用它时,延迟都会增加一倍,更不用说我有超过 10 个传感器需要在同一页面中进行此查询。我做错了还是有一些更有效的方法可以从收集中获取最新数据?

编辑:@Sammaye:我尝试根据您的建议创建索引,这是执行查询后生成的解释:

"cursor" : "BtreeCursor timestamp_desc",
    "nscanned" : 326678,
    "nscannedObjects" : 326678,
    "n" : 50,
    "millis" : 4402,
    "nYields" : 7,
    "nChunkSkips" : 0,
    "isMultiKey" : false,
    "indexOnly" : false,
    "indexBounds" : {
            "timestamp" : [
                    [
                            {
                                    "$maxElement" : 1
                            },
                            {
                                    "$minElement" : 1
                            }
                    ]
            ]
    }

根据比较,这解释了不使用索引的第一个查询(执行速度更快):

"cursor" : "BasicCursor",
    "nscanned" : 385517,
    "nscannedObjects" : 385517,
    "n" : 50,
    "millis" : 1138,
    "nYields" : 0,
    "nChunkSkips" : 0,
    "isMultiKey" : false,
    "indexOnly" : false,
    "indexBounds" : {

    }
4

1 回答 1

2

好的,谢谢大家的好评:)这是我尝试使用索引后的发现:

  1. 将 mongodb 更新到最新版本。我发现这稍微改善了我的查询。我正在从 ubuntu 12.04.02 中默认提供的默认 2.0.3 更新到 mongodb 版本 2.4.3
  2. 完全根据您在查询中最需要的方式构建索引/复合索引。例如,在我的问题中,我的查询基于SensorIdand _id: DESCENDING 所以优化我的查询的最佳策略是这样的: db.your_collection.ensureIndex({ "SourceId" : 1, "_id" : -1 },{ "name" : "sourceid_idx", "background" : true }); 或者在其他情况下,如果我需要它基于时间戳:

    db.your_collection.ensureIndex({ "SourceId" : 1, "timestamp" : -1 },{ "name" : "source_idx", "background" : true });

我在这里找到了关于 mongodb 索引的很好的解释

希望这会帮助其他偶然发现类似问题的人......

于 2013-05-21T09:16:22.563 回答