-
Notifications
You must be signed in to change notification settings - Fork 533
Expand file tree
/
Copy pathServerSideMetricsInternalAccumulator.cs
More file actions
82 lines (73 loc) · 3.91 KB
/
ServerSideMetricsInternalAccumulator.cs
File metadata and controls
82 lines (73 loc) · 3.91 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
//------------------------------------------------------------
// Copyright (c) Microsoft Corporation. All rights reserved.
//------------------------------------------------------------
namespace Microsoft.Azure.Cosmos.Query.Core.Metrics
{
using System;
using System.Collections.Generic;
internal sealed class ServerSideMetricsInternalAccumulator
{
private readonly List<ServerSideMetricsInternal> serverSideMetricsList;
public ServerSideMetricsInternalAccumulator()
{
this.serverSideMetricsList = new List<ServerSideMetricsInternal>();
}
public void Accumulate(ServerSideMetricsInternal serverSideMetrics)
{
if (serverSideMetrics == null)
{
throw new ArgumentNullException(nameof(serverSideMetrics));
}
this.serverSideMetricsList.Add(serverSideMetrics);
}
public ServerSideMetricsInternal GetServerSideMetrics()
{
TimeSpan totalTime = TimeSpan.Zero;
long retrievedDocumentCount = 0;
long retrievedDocumentSize = 0;
long outputDocumentCount = 0;
long outputDocumentSize = 0;
double indexHitRatio = 0;
QueryPreparationTimesAccumulator queryPreparationTimesAccumulator = new QueryPreparationTimesAccumulator();
TimeSpan indexLookupTime = TimeSpan.Zero;
TimeSpan documentLoadTime = TimeSpan.Zero;
RuntimeExecutionTimesAccumulator runtimeExecutionTimesAccumulator = new RuntimeExecutionTimesAccumulator();
TimeSpan documentWriteTime = TimeSpan.Zero;
TimeSpan vMExecutionTime = TimeSpan.Zero;
foreach (ServerSideMetricsInternal serverSideMetrics in this.serverSideMetricsList)
{
indexHitRatio = (retrievedDocumentCount + serverSideMetrics.RetrievedDocumentCount) != 0 ?
((retrievedDocumentCount * indexHitRatio) + (serverSideMetrics.RetrievedDocumentCount * serverSideMetrics.IndexHitRatio)) / (retrievedDocumentCount + serverSideMetrics.RetrievedDocumentCount) :
0;
totalTime += serverSideMetrics.TotalTime;
retrievedDocumentCount += serverSideMetrics.RetrievedDocumentCount;
retrievedDocumentSize += serverSideMetrics.RetrievedDocumentSize;
outputDocumentCount += serverSideMetrics.OutputDocumentCount;
outputDocumentSize += serverSideMetrics.OutputDocumentSize;
queryPreparationTimesAccumulator.Accumulate(serverSideMetrics.QueryPreparationTimes);
indexLookupTime += serverSideMetrics.IndexLookupTime;
documentLoadTime += serverSideMetrics.DocumentLoadTime;
runtimeExecutionTimesAccumulator.Accumulate(serverSideMetrics.RuntimeExecutionTimes);
documentWriteTime += serverSideMetrics.DocumentWriteTime;
vMExecutionTime += serverSideMetrics.VMExecutionTime;
}
return new ServerSideMetricsInternal(
retrievedDocumentCount: retrievedDocumentCount,
retrievedDocumentSize: retrievedDocumentSize,
outputDocumentCount: outputDocumentCount,
outputDocumentSize: outputDocumentSize,
indexHitRatio: indexHitRatio,
totalQueryExecutionTime: totalTime,
queryPreparationTimes: queryPreparationTimesAccumulator.GetQueryPreparationTimes(),
indexLookupTime: indexLookupTime,
documentLoadTime: documentLoadTime,
vmExecutionTime: vMExecutionTime,
runtimeExecutionTimes: runtimeExecutionTimesAccumulator.GetRuntimeExecutionTimes(),
documentWriteTime: documentWriteTime);
}
public List<ServerSideMetricsInternal> GetPartitionedServerSideMetrics()
{
return this.serverSideMetricsList;
}
}
}