1

トレース コレクション ( http://docs.mongodb.org/manual/tutorial/create-tailable-cursor )を読み取るために、tailable カーソルを使用しています。これはうまくいくようですが、次のような遅いクエリがログに記録されています。

Tue Jan 15 17:54:37 [conn28] getmore trace.traces query: { time: { $gte: new Date(1358254406370) } } cursorid:7095190436798608732 reslen:20 2268ms
Tue Jan 15 17:54:38 [conn28] getmore trace.traces query: { time: { $gte: new Date(1358254406370) } } cursorid:7095190436798608732 nreturned:1 reslen:513 315ms
Tue Jan 15 17:54:39 [conn28] getmore trace.traces query: { time: { $gte: new Date(1358254406370) } } cursorid:7095190436798608732 nreturned:2 reslen:1800 962ms
Tue Jan 15 17:54:41 [conn28] getmore trace.traces query: { time: { $gte: new Date(1358254406370) } } cursorid:7095190436798608732 reslen:20 2268ms
Tue Jan 15 17:54:43 [conn28] getmore trace.traces query: { time: { $gte: new Date(1358254406370) } } cursorid:7095190436798608732 reslen:20 2283ms

コレクションにまったく書き込んでいない場合でも、行は数秒ごとにログに記録され続けます。

Mongo 2.0.8 (および Java Driver 2.10.1) を使用しています。Mongo 2.2.2 でも試してみましたが、ここでは (--profile 2 を使用しても) ログに記録されませんが、system.profile コレクションにはまだ表示されます。

このクエリが遅い(と報告されている)理由を知っている人はいますか?

プロフィール情報は次のとおりです。

> db.system.profile.find().limit(1).sort( { millis : -1 } ).pretty()
{
    "ts" : ISODate("2013-01-15T17:33:48.354Z"),
    "op" : "getmore",
    "ns" : "trace.traces",
    "query" : {
            "time" : {
                    "$gte" : ISODate("2013-01-15T12:56:57.589Z")
            }
    },
    "cursorid" : NumberLong("8205177764687670896"),
    "ntoreturn" : 0,
    "keyUpdates" : 0,
    "numYield" : 0,
    "lockStats" : {
            "timeLockedMicros" : {
                    "r" : NumberLong(30492),
                    "w" : NumberLong(0)
            },
            "timeAcquiringMicros" : {
                    "r" : NumberLong(22499),
                    "w" : NumberLong(3)
            }
    },
    "nreturned" : 0,
    "responseLength" : 20,
    "millis" : 2356,
    "client" : "127.0.0.1",
    "user" : ""
}

コレクションの統計は次のとおりです。

> db.traces.stats()
{
    "ns" : "trace.traces",
    "count" : 41897,
    "size" : 51760464,
    "avgObjSize" : 1235.4217247058261,
    "storageSize" : 52432896,
    "numExtents" : 1,
    "nindexes" : 1,
    "lastExtentSize" : 52432896,
    "paddingFactor" : 1,
    "systemFlags" : 1,
    "userFlags" : 0,
    "totalIndexSize" : 1422624,
    "indexSizes" : {
            "_id_" : 1422624
    },
    "capped" : true,
    "max" : 2147483647,
    "ok" : 1
}
4

1 に答える 1

1

利用可能なドキュメントがない場合、カーソルが新しいドキュメントの待機をブロックしていると思います。遅いクエリがすべて持っていることを確認してくださいreslen:20。これは私には正常な動作のように見えます。

于 2013-01-16T11:31:14.013 に答える