若RU代表的是请求单元数,则会遇到以下情况:
在Cosmos DB中,RU每小时是指每小时可消耗的请求单元数(共计RU),而RU利用率是在一个小时内实际消耗的请求单元数(实际RU)。如果两者的数值不匹配,则可能会发现Autoscale计费时产生错误。
以下示例显示如何通过包括跟踪RU消耗和Autoscale计费的代码来解决此问题:
在使用Cosmos DB SDK执行查询的代码中包含以下代码行,以跟踪RU消耗:
FeedOptions queryOptions = new FeedOptions { EnableCrossPartitionQuery = true, MaxItemCount = -1, RequestContinuation = continuationToken, MaxDegreeOfParallelism = -1 };
queryOptions.PopulateQueryMetrics = true;
在使用Cosmos DB SDK执行查询的代码中包含以下代码行,以计算实际RU消耗:
double totalRU = 0;
foreach (var p in feedResponse.QueryMetrics)
{
totalRU += p.Value.TotalRequestUnits;
}
在Autoscale计费期间,在执行查询或其他操作之前,在开始进行任何操作之前获取集合配置,并将RU/小时与所需RU比较:
var cosmosClient = new CosmosClient(cosmosDBConnectionString);
var database = cosmosClient.GetDatabase(databaseName);
var container = database.GetContainer(containerName);
var response = await container.ReadThroughputAsync();
var throughput = response.Resource.ThroughputProperties;
double requiredRU = (double)(containerCharge * (3600.0 / 1000000.0));
if (requiredRU > throughput.AutoscaleMaxThroughput)
{
// Do something to fix the issue
}
在上述代码示例中,containerCharge代表每秒需要的RU数量,而AutoscaleMaxThroughput代表在一个小时内可以使用的最大RU数量。
如果实际