【问题标题】:MongoDB C# Driver tailable cursor on oplog.rsoplog.rs 上的 MongoDB C# 驱动程序可尾游标
【发布时间】:2013-03-06 20:01:15
【问题描述】:

我正在尝试使用类似于 Java Here 中实现的 MongoDB C# 驱动程序编写一个 oplog 观察程序。

到目前为止,我已经设法写了:

public static void Read()
{
    const string connectionString = "mongodb://127.0.0.1:27017,127.0.0.1:27018/?replicaSet=rs0";
    MongoClient mongoClient = new MongoClient(connectionString);

    MongoDatabase local = mongoClient.GetServer().GetDatabase("local");
    MongoCollection opLog = local.GetCollection("oplog.$main");
    BsonValue lastId = BsonMinKey.Value;
    while (true)
    {
        var query = Query.GT("_id", lastId);
        var cursor = opLog.FindAs<BsonDocument>(query)
                    .SetFlags(
                        QueryFlags.AwaitData |
                        QueryFlags.TailableCursor |
                        QueryFlags.NoCursorTimeout)
                    .SetSortOrder(SortBy.Ascending("$natural"));
        using (var enumerator = (MongoCursorEnumerator<BsonDocument>)cursor.GetEnumerator())
        {
            while (true)
            {
            // I get a "tailable cursor requested on non capped collection" Exception
                if (enumerator.MoveNext())
                {
                    var document = enumerator.Current;
                    lastId = document["_id"];
                }
                else
                {
                    if (enumerator.IsDead)
                    {
                        break;
                    }
                    if (!enumerator.IsServerAwaitCapable)
                    {
                        Thread.Sleep(TimeSpan.FromMilliseconds(100));
                    }
                }
            }
        }
    }
}

我已经在服务器上创建了 oplog,并使用找到的指令从 mongo 命令行成功查询了它here,但我无法弄清楚为什么异常说它没有上限。

【问题讨论】:

  • 我已经查看了this c# implementation,但它创建了一个新的上限集合,我对 oplog.rs 更感兴趣。

标签: mongodb mongodb-.net-driver


【解决方案1】:

如果你正在使用并设置了一个副本集,那么你就有一个 oplog。

要查询 oplog,您可以像以前一样使用“本地”数据库。

然后改变

local.GetCollection("oplog.$main");

local.GetCollection("oplog.rs");

【讨论】:

  • 感谢您的建议,它解决了问题。我很好奇,但如果你能解释链接示例中“oplog.$main”的确切意义是什么?如果没有启用副本集,是否会创建文件?
  • 不确定名称“oplog.$main”。它可能是旧 mongod 命名的遗产。至于 oplog,它是为复制而创建的,如果没有创建副本集则不是。您可能听说过日志文件,但它们不是 oplog - 请参阅 stackoverflow.com/questions/8970739/…
  • 好的,感谢您提供的额外信息。事实上,我对 oplog 感兴趣,而不是日志文件。
猜你喜欢
  • 1970-01-01
  • 2012-10-02
  • 1970-01-01
  • 1970-01-01
  • 2023-03-20
  • 2016-03-13
  • 1970-01-01
  • 1970-01-01
  • 2011-08-19
相关资源
最近更新 更多