使用 ORDER BY 记录 DB SDK 导致 ServiceUnvailableException

duy*_*duy 5 database indexing azure-sdk-.net azure-cosmosdb

我正在使用 DocumentDB。给定索引策略:

消息类型:字符串 - 精度 -1

设备编号 : 字符串 - 精度 -1

查询 1:

SELECT * FROM c WHERE c._ts >= 1563721200 AND c._ts < 1563807600 AND c.messageType = 'attack' AND c.deviceId >= 'A' AND c.deviceId < 'Z'
Run Code Online (Sandbox Code Playgroud)

查询 2:

SELECT * FROM c WHERE c._ts >= 1563721200 AND c._ts < 1563807600 AND c.messageType = 'attack' AND c.deviceId >= 'A' AND c.deviceId < 'Z' ORDER BY c._ts DESC
Run Code Online (Sandbox Code Playgroud)

执行代码:

var query = dbClientSource.CreateDocumentQuery<Document(UriFactory.CreateDocumentCollectionUri(db, collection),
             sql,
             new FeedOptions { MaxItemCount = 100, EnableCrossPartitionQuery = true })
             .AsDocumentQuery();
while (query.HasMoreResults)
       var result = await query.ExecuteNextAsync<Telemetry>();
Run Code Online (Sandbox Code Playgroud)

查询 1 有效,但查询 2 抛出异常:

{
  "code": "ServiceUnavailable",
  "message": "The request failed because the client was unable to establish connections to 1 endpoints across 1 regions. The client CPU was overloaded during the attempted request.
}
Run Code Online (Sandbox Code Playgroud)

不同的是“ORDER BY”命令。有什么解决办法吗?

duy*_*duy 2

我在门户网站中测试了查询 2,它的工作方式就像一个魅力。因此,在应用程序中我将 ConnectionPolicy 更改为:

网关 - HTTPS

现在应用程序正在运行。这个问题看起来与 Document DB SDK 有关,以确保我将继续测试并向 Github 存储库报告。