【发布时间】:2012-01-05 05:11:25
【问题描述】:
我正在运行一个 MongoDB 服务器(实际上就是它所运行的全部内容)。该服务器具有 64GB 的 RAM 和 16 个内核,外加 2TB 的硬盘空间可供使用。
文档结构
该数据库有一个集合domains,其中包含大约 2000 万个文档。每个文档中都有相当数量的数据,但出于我们的目的,该文档的结构如下:
{
_id: "abcxyz.com",
LastUpdated: <date>,
...
}
_id 字段是文档引用的域名。 LastUpdated 上有一个升序索引。 LastUpdated 每天更新数十万条记录。基本上每次新数据可用于文档时,文档都会更新,并且 LastUpdated 字段会更新为当前日期/时间。
查询
我有一种从数据库中提取数据的机制,因此可以在 Lucene 索引中对其进行索引。 LastUpdated 字段是标记对文档所做更改的关键驱动程序。为了搜索已更改的文档并翻阅这些文档,我执行以下操作:
{
LastUpdated: { $gte: ISODate(<firstdate>), $lt: ISODate(<lastdate>) },
_id: { $gt: <last_id_from_previous_page> }
}
sort: { $_id:1 }
当没有文档返回时,开始和结束日期向前移动,_id“锚”字段被重置。此设置可以容忍先前页面中的文档已更改其 LastUpdated 值,即分页不会被先前页面中的文档数量错误地抵消,这些文档在技术上不再在这些页面中。
问题
理想情况下,我希望一次选择大约 25000 个文档,但由于某种原因,查询本身(即使只选择 非常很慢。
我运行的查询是:
db.domains.find({
"LastUpdated" : {
"$gte" : ISODate("2011-11-22T15:01:54.851Z"),
"$lt" : ISODate("2011-11-22T17:39:48.013Z")
},
"_id" : { "$gt" : "1300broadband.com" }
}).sort({ _id:1 }).limit(50).explain()
事实上,解释(在撰写本文时)已经运行了 10 多分钟并且尚未完成,这实在是太慢了。如果它完成了,我会更新这个问题,但问题当然是查询非常慢。
我能做什么?我不知道查询可能存在什么问题。
编辑 讲解在 55 分钟后结束。这里是:
{
"cursor" : "BtreeCursor Lastupdated_-1__id_1",
"nscanned" : 13112,
"nscannedObjects" : 13100,
"n" : 50,
"scanAndOrder" : true,
"millis" : 3347845,
"nYields" : 5454,
"nChunkSkips" : 0,
"isMultiKey" : false,
"indexOnly" : false,
"indexBounds" : {
"LastUpdated" : [
[
ISODate("2011-11-22T17:39:48.013Z"),
ISODate("2011-11-22T15:01:54.851Z")
]
],
"_id" : [
[
"1300broadband.com",
{
}
]
]
}
}
【问题讨论】:
标签: mongodb