首页 > 解决方案 > ChangeStreamDocument.ClusterTime 总是抛出 FormatException

问题描述

我在 Windows 7 上使用net461/netstandard2.0dll 中的 MongoDB.Driver 2.7.0 针对社区服务器 4.0.2 的本地安装并配置了单个副本集。

我正在收听集合上的更改流,但是当我只是尝试访问ClusterTime结果的属性时,ChangeStreamDocument它会引发异常:

    private static DateTime? GetTimeStamp(ChangeStreamDocument<T> csd)
    {
        try
        {
            var clusterTime = csd.ClusterTime; // BOOM
            return clusterTime.ToNullableUniversalTime();
        }
        catch
        {
            return null;
        }
    }

  System.FormatException
  HResult=0x80131537
  Message=Cannot deserialize a 'BsonDocument' from BsonType 'Timestamp'.
  Source=MongoDB.Bson
  StackTrace:
   at MongoDB.Bson.Serialization.Serializers.SerializerBase`1.EnsureBsonTypeEquals(IBsonReader reader, BsonType bsonType)
   at MongoDB.Bson.Serialization.Serializers.BsonValueSerializerBase`1.Deserialize(BsonDeserializationContext context, BsonDeserializationArgs args)
   at MongoDB.Bson.Serialization.Serializers.SerializerBase`1.MongoDB.Bson.Serialization.IBsonSerializer.Deserialize(BsonDeserializationContext context, BsonDeserializationArgs args)
   at MongoDB.Bson.Serialization.IBsonSerializerExtensions.Deserialize(IBsonSerializer serializer, BsonDeserializationContext context)
   at MongoDB.Bson.Serialization.BsonSerializationInfo.DeserializeValue(BsonValue value)
   at MongoDB.Bson.Serialization.BsonDocumentBackedClass.GetValue[T](String memberName, T defaultValue)
   at Foo.GetTimeStamp(ChangeStreamDocument`1 csd) in Foo.cs:line 28

查看支持文件,clusterTime确实是Timestamp

{
  "_id": {
    "_data": "825B9102E30000000129295A1004BFB7B7E0A5F648929251FC06F06640A2463C5F6964003C62366332623361352D313965352D343162392D386336322D396565313130393337666634000004"
  },
  "operationType": "insert",
  "clusterTime": Timestamp(1536230115, 1),
  // ... omitted
}

这是错误/已知问题还是我的设置有问题?

标签: c#.netmongodb

解决方案


这已被 MongoDB 确认为一个错误。


推荐阅读