Mongodb C#'System.TimeoutException

时间:2017-09-26 05:42:37

标签: c# mongodb visual-studio

我在mongodb中遇到了一个奇怪的例外。我在vs中写了一个简单的服务,并且工作到昨晚。但现在当我通过VS运行我的服务时,我得到了这个例外:

An exception of type 'System.TimeoutException' occurred in MongoDB.Driver.Core.dll but was not handled in user code

Additional information: A timeout occured after 30000ms selecting a  server using CompositeServerSelector{ Selectors =  ReadPreferenceServerSelector{ ReadPreference = { Mode = Primary, TagSets = []  } }, LatencyLimitingServerSelector{ AllowedLatencyRange = 00:00:00.0150000 }  }. Client view of cluster state is { ClusterId : "1", ConnectionMode :  "Automatic", Type : "Unknown", State : "Disconnected", Servers : [{ ServerId:  "{ ClusterId : 1, EndPoint : "127.0.0.1:27017" }", EndPoint:  "127.0.0.1:27017", State: "Disconnected", Type: "Unknown",  HeartbeatException: "MongoDB.Driver.MongoConnectionException: An exception  occurred while opening a connection to the server. --->  System.Net.Sockets.SocketException: No connection could be made because the  target machine actively refused it 127.0.0.1:27017

at System.Net.Sockets.Socket.EndConnect(IAsyncResult asyncResult)

at System.Threading.Tasks.TaskFactory`1.FromAsyncCoreLogic(IAsyncResult  iar, Func`2 endFunction, Action`1 endAction, Task`1 promise, Boolean  requiresSynchronization)

--- End of stack trace from previous location where exception was thrown ---

at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)

at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)

at MongoDB.Driver.Core.Connections.TcpStreamFactory.<ConnectAsync>d__7.MoveNext()

--- End of stack trace from previous location where exception was thrown ---

at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)

at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)

at MongoDB.Driver.Core.Connections.TcpStreamFactory.<CreateStreamAsync>d__4.MoveNext()

--- End of stack trace from previous location where exception was thrown ---

at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)

at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)

at MongoDB.Driver.Core.Connections.BinaryConnection.<OpenHelperAsync>d__47.MoveNext()

 --- End of inner exception stack trace ---

at MongoDB.Driver.Core.Connections.BinaryConnection.<OpenHelperAsync>d__47.MoveNext()

 --- End of stack trace from previous location where exception was thrown ---

at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)

at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)

at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)

at MongoDB.Driver.Core.Servers.ClusterableServer.<HeartbeatAsync>d__42.MoveNext()" }] }.

为什么我得到这个例外,我该如何处理呢? 为什么我的服务以前运作良好? 这是我得到这个例外的地方:

        public static IList<Location> GetFinalLocationsInTopicInLocationTable(string topic)
    {
        logger.Trace(Constants.LOG_MESSAGE_METHOD_STARTED);

        var collection = GetDbMongo().GetCollection<Location>(DB_COLLECTION_LOCATIONS);
        var matchFilter = Builders<Location>.Filter.Regex("Topic", topic);
        var groupFilter = new BsonDocument { { "_id", "$DeviceId" }, { "max", new BsonDocument("$max", "$CreationDateTime") } };

        var location = collection
            .Aggregate()
         .Match(matchFilter)
         .Group(groupFilter)
         .ToList();     // -----I got this exception

1 个答案:

答案 0 :(得分:0)

我解决了这个问题。我的问题是: my mongodb service was stopped。我不知道为什么它会停止但是当我开始它时,问题就消失了。