@cdklabs/multi-az-observability 0.0.1-alpha.3 → 0.0.1-alpha.31
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +374 -147
- package/API.md +292 -100
- package/README.md +21 -14
- package/cdk.json +1 -1
- package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.d.ts +7 -7
- package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.js +35 -35
- package/lib/alarmsandrules/BaseOperationRegionalAlarmsAndRules.js +2 -2
- package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.d.ts +6 -15
- package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.js +2 -10
- package/lib/alarmsandrules/CanaryOperationZonalAlarmsAndRules.d.ts +11 -3
- package/lib/alarmsandrules/CanaryOperationZonalAlarmsAndRules.js +24 -13
- package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.d.ts +0 -8
- package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.js +1 -1
- package/lib/alarmsandrules/IOperationAlarmsAndRules.d.ts +19 -27
- package/lib/alarmsandrules/IOperationAlarmsAndRules.js +1 -1
- package/lib/alarmsandrules/IServerSideOperationRegionalAlarmsAndRules.js +1 -1
- package/lib/alarmsandrules/IServiceAlarmsAndRules.d.ts +0 -8
- package/lib/alarmsandrules/IServiceAlarmsAndRules.js +1 -1
- package/lib/alarmsandrules/OperationAlarmsAndRules.d.ts +14 -22
- package/lib/alarmsandrules/OperationAlarmsAndRules.js +51 -71
- package/lib/alarmsandrules/ServerSideOperationRegionalAlarmsAndRules.d.ts +5 -5
- package/lib/alarmsandrules/ServerSideOperationRegionalAlarmsAndRules.js +2 -3
- package/lib/alarmsandrules/ServerSideOperationZonalAlarmsAndRules.d.ts +21 -13
- package/lib/alarmsandrules/ServerSideOperationZonalAlarmsAndRules.js +43 -29
- package/lib/alarmsandrules/ServiceAlarmsAndRules.d.ts +0 -2
- package/lib/alarmsandrules/ServiceAlarmsAndRules.js +61 -39
- package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.d.ts +6 -44
- package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.js +1 -1
- package/lib/alarmsandrules/props/OperationAlarmsAndRulesProps.d.ts +28 -7
- package/lib/alarmsandrules/props/OperationAlarmsAndRulesProps.js +1 -1
- package/lib/azmapper/AvailabilityZoneMapper.js +4 -3
- package/lib/basic_observability/BasicServiceDashboard.d.ts +0 -3
- package/lib/basic_observability/BasicServiceDashboard.js +24 -112
- package/lib/basic_observability/BasicServiceMultiAZObservability.d.ts +8 -9
- package/lib/basic_observability/BasicServiceMultiAZObservability.js +100 -312
- package/lib/basic_observability/props/ApplicationLoadBalancerDetectionProps.d.ts +50 -0
- package/lib/basic_observability/props/ApplicationLoadBalancerDetectionProps.js +3 -0
- package/lib/basic_observability/props/BasicServiceDashboardProps.d.ts +27 -13
- package/lib/basic_observability/props/BasicServiceDashboardProps.js +1 -1
- package/lib/basic_observability/props/BasicServiceMultiAZObservabilityProps.d.ts +10 -38
- package/lib/basic_observability/props/BasicServiceMultiAZObservabilityProps.js +1 -1
- package/lib/basic_observability/props/NatGatewayDetectionProps.d.ts +31 -0
- package/lib/basic_observability/props/NatGatewayDetectionProps.js +3 -0
- package/lib/canaries/CanaryFunction.js +7 -6
- package/lib/canaries/src/canary.zip +0 -0
- package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.d.ts +2 -6
- package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.js +440 -506
- package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.d.ts +0 -1
- package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.js +56 -113
- package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.d.ts +3 -66
- package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.js +1 -1
- package/lib/dashboards/props/OperationAvailabilityWidgetProps.d.ts +7 -2
- package/lib/dashboards/props/OperationAvailabilityWidgetProps.js +1 -1
- package/lib/dashboards/props/OperationLatencyWidgetProps.d.ts +7 -2
- package/lib/dashboards/props/OperationLatencyWidgetProps.js +1 -1
- package/lib/index.d.ts +5 -0
- package/lib/index.js +8 -2
- package/lib/metrics/ApplicationLoadBalancerMetrics.d.ts +72 -4
- package/lib/metrics/ApplicationLoadBalancerMetrics.js +671 -33
- package/lib/metrics/AvailabilityAndLatencyMetrics.d.ts +23 -0
- package/lib/metrics/AvailabilityAndLatencyMetrics.js +117 -24
- package/lib/metrics/NatGatewayMetrics.d.ts +113 -0
- package/lib/metrics/NatGatewayMetrics.js +357 -0
- package/lib/metrics/RegionalLatencyMetrics.d.ts +1 -1
- package/lib/metrics/RegionalLatencyMetrics.js +27 -20
- package/lib/metrics/ZonalAvailabilityMetrics.d.ts +2 -8
- package/lib/metrics/ZonalAvailabilityMetrics.js +10 -25
- package/lib/metrics/ZonalLatencyMetrics.d.ts +2 -1
- package/lib/metrics/ZonalLatencyMetrics.js +33 -23
- package/lib/metrics/props/AvailabilityAndLatencyMetricProps.d.ts +4 -0
- package/lib/metrics/props/AvailabilityAndLatencyMetricProps.js +1 -1
- package/lib/metrics/props/LatencyMetricProps.d.ts +6 -0
- package/lib/metrics/props/LatencyMetricProps.js +1 -1
- package/lib/metrics/props/ZonalAvailabilityMetricProps.d.ts +4 -0
- package/lib/metrics/props/ZonalAvailabilityMetricProps.js +1 -1
- package/lib/metrics/props/ZonalLatencyMetricProps.d.ts +4 -0
- package/lib/metrics/props/ZonalLatencyMetricProps.js +1 -1
- package/lib/monitoring/src/monitoring-layer.zip +0 -0
- package/lib/outlier-detection/ApplicationLoadBalancerAvailabilityOutlierAlgorithm.d.ts +10 -0
- package/lib/outlier-detection/ApplicationLoadBalancerAvailabilityOutlierAlgorithm.js +15 -0
- package/lib/outlier-detection/ApplicationLoadBalancerLatencyOutlierAlgorithm.d.ts +18 -0
- package/lib/outlier-detection/ApplicationLoadBalancerLatencyOutlierAlgorithm.js +23 -0
- package/lib/outlier-detection/OutlierDetectionFunction.js +6 -5
- package/lib/outlier-detection/PacketLossOutlierAlgorithm.d.ts +10 -0
- package/lib/outlier-detection/PacketLossOutlierAlgorithm.js +15 -0
- package/lib/outlier-detection/src/outlier-detection.zip +0 -0
- package/lib/outlier-detection/src/scipy-layer.zip +0 -0
- package/lib/services/CanaryMetrics.js +1 -1
- package/lib/services/CanaryTestMetricsOverride.js +1 -1
- package/lib/services/ContributorInsightRuleDetails.js +1 -1
- package/lib/services/InstrumentedServiceMultiAZObservability.d.ts +10 -0
- package/lib/services/InstrumentedServiceMultiAZObservability.js +188 -194
- package/lib/services/Operation.js +1 -1
- package/lib/services/OperationMetricDetails.js +1 -1
- package/lib/services/Service.js +1 -1
- package/lib/services/ServiceMetricDetails.js +1 -1
- package/lib/services/props/MetricDimensions.js +1 -1
- package/lib/utilities/MetricsHelper.d.ts +15 -10
- package/lib/utilities/MetricsHelper.js +19 -11
- package/package.json +8 -8
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { IMetric } from 'aws-cdk-lib/aws-cloudwatch';
|
|
2
2
|
import { AvailabilityMetricProps } from './props/AvailabilityMetricProps';
|
|
3
3
|
import { LatencyMetricProps } from './props/LatencyMetricProps';
|
|
4
|
+
import { ZonalAvailabilityMetricProps } from './props/ZonalAvailabilityMetricProps';
|
|
5
|
+
import { ZonalLatencyMetricProps } from './props/ZonalLatencyMetricProps';
|
|
4
6
|
/**
|
|
5
7
|
* Class for creating availability and latency metrics that can be used in alarms and graphs
|
|
6
8
|
*/
|
|
@@ -14,6 +16,15 @@ export declare class AvailabilityAndLatencyMetrics {
|
|
|
14
16
|
static createAvailabilityMetric(props: AvailabilityMetricProps, dimensions: {
|
|
15
17
|
[key: string]: string;
|
|
16
18
|
}): IMetric;
|
|
19
|
+
/**
|
|
20
|
+
* Creates availability metrics for a specific AZ
|
|
21
|
+
* @param props
|
|
22
|
+
* @param dimensions
|
|
23
|
+
* @returns
|
|
24
|
+
*/
|
|
25
|
+
static createZonalAvailabilityMetric(props: ZonalAvailabilityMetricProps, dimensions: {
|
|
26
|
+
[key: string]: string;
|
|
27
|
+
}): IMetric;
|
|
17
28
|
/**
|
|
18
29
|
* General purpose method to create latency metrics, the reason this creates an array of metrics while the
|
|
19
30
|
* equivalent availability metric method doesn't is because in availability, we can just sum the count of different
|
|
@@ -28,6 +39,15 @@ export declare class AvailabilityAndLatencyMetrics {
|
|
|
28
39
|
static createLatencyMetrics(props: LatencyMetricProps, dimensions: {
|
|
29
40
|
[key: string]: string;
|
|
30
41
|
}): IMetric[];
|
|
42
|
+
/**
|
|
43
|
+
* Creates a latency metric with the provided name
|
|
44
|
+
* @param props
|
|
45
|
+
* @param dimensions
|
|
46
|
+
* @returns
|
|
47
|
+
*/
|
|
48
|
+
static createLatencyMetric(props: LatencyMetricProps, dimensions: {
|
|
49
|
+
[key: string]: string;
|
|
50
|
+
}): IMetric;
|
|
31
51
|
/**
|
|
32
52
|
* Takes all of the success or failure latency metric names and creates an average of those
|
|
33
53
|
* names, if there's only 1 name, it just returns that metric
|
|
@@ -47,4 +67,7 @@ export declare class AvailabilityAndLatencyMetrics {
|
|
|
47
67
|
static createLatencyCountMetric(props: LatencyMetricProps, dimensions: {
|
|
48
68
|
[key: string]: string;
|
|
49
69
|
}): IMetric;
|
|
70
|
+
static createZonalLatencyCountMetric(props: ZonalLatencyMetricProps, dimensions: {
|
|
71
|
+
[key: string]: string;
|
|
72
|
+
}): IMetric;
|
|
50
73
|
}
|
|
@@ -17,21 +17,13 @@ class AvailabilityAndLatencyMetrics {
|
|
|
17
17
|
* @returns
|
|
18
18
|
*/
|
|
19
19
|
static createAvailabilityMetric(props, dimensions) {
|
|
20
|
-
let counter = 0;
|
|
21
|
-
let key = '';
|
|
22
20
|
let usingMetrics = {};
|
|
23
21
|
let successKeys = [];
|
|
24
22
|
let faultKeys = [];
|
|
25
23
|
if (props.metricDetails.successMetricNames !== undefined &&
|
|
26
24
|
props.metricType != AvailabilityMetricType_1.AvailabilityMetricType.FAULT_COUNT) {
|
|
27
25
|
props.metricDetails.successMetricNames.forEach((successMetric) => {
|
|
28
|
-
let
|
|
29
|
-
? ''
|
|
30
|
-
: props.keyPrefix.toLowerCase() + '_') +
|
|
31
|
-
props.metricDetails.operationName.toLowerCase() +
|
|
32
|
-
'_' +
|
|
33
|
-
successMetric.toLowerCase();
|
|
34
|
-
key = keyPrefix + '_' + counter++;
|
|
26
|
+
let key = `${props.metricDetails.operationName.toLowerCase()}_${props.metricType.toString().toLowerCase()}_${successMetric.toLowerCase()}`;
|
|
35
27
|
successKeys.push(key);
|
|
36
28
|
usingMetrics[key] = new aws_cloudwatch_1.Metric({
|
|
37
29
|
namespace: props.metricDetails.metricNamespace,
|
|
@@ -47,13 +39,75 @@ class AvailabilityAndLatencyMetrics {
|
|
|
47
39
|
if (props.metricDetails.faultMetricNames !== undefined &&
|
|
48
40
|
props.metricType != AvailabilityMetricType_1.AvailabilityMetricType.SUCCESS_COUNT) {
|
|
49
41
|
props.metricDetails.faultMetricNames.forEach((faultMetric) => {
|
|
50
|
-
let
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
props.metricDetails.
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
42
|
+
let key = `${props.metricDetails.operationName.toLowerCase()}_${props.metricType.toString().toLowerCase()}_${faultMetric.toLowerCase()}`;
|
|
43
|
+
faultKeys.push(key);
|
|
44
|
+
usingMetrics[key] = new aws_cloudwatch_1.Metric({
|
|
45
|
+
namespace: props.metricDetails.metricNamespace,
|
|
46
|
+
metricName: faultMetric,
|
|
47
|
+
unit: props.metricDetails.unit,
|
|
48
|
+
period: props.metricDetails.period,
|
|
49
|
+
statistic: props.metricDetails.alarmStatistic,
|
|
50
|
+
dimensionsMap: dimensions,
|
|
51
|
+
label: faultMetric,
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
let expression = '';
|
|
56
|
+
switch (props.metricType) {
|
|
57
|
+
case AvailabilityMetricType_1.AvailabilityMetricType.SUCCESS_RATE:
|
|
58
|
+
expression = `((${successKeys.join('+')}) / (${successKeys.join('+')}+${faultKeys.join('+')})) * 100`;
|
|
59
|
+
break;
|
|
60
|
+
case AvailabilityMetricType_1.AvailabilityMetricType.REQUEST_COUNT:
|
|
61
|
+
expression = `${successKeys.join('+')}+${faultKeys.join('+')}`;
|
|
62
|
+
break;
|
|
63
|
+
case AvailabilityMetricType_1.AvailabilityMetricType.FAULT_COUNT:
|
|
64
|
+
expression = `(${faultKeys.join('+')})`;
|
|
65
|
+
break;
|
|
66
|
+
case AvailabilityMetricType_1.AvailabilityMetricType.FAULT_RATE:
|
|
67
|
+
expression = `((${faultKeys.join('+')}) / (${successKeys.join('+')}+${faultKeys.join('+')})) * 100`;
|
|
68
|
+
break;
|
|
69
|
+
case AvailabilityMetricType_1.AvailabilityMetricType.SUCCESS_COUNT:
|
|
70
|
+
expression = `(${successKeys.join('+')})`;
|
|
71
|
+
break;
|
|
72
|
+
}
|
|
73
|
+
return new aws_cloudwatch_1.MathExpression({
|
|
74
|
+
expression: expression,
|
|
75
|
+
label: props.label,
|
|
76
|
+
period: props.metricDetails.period,
|
|
77
|
+
usingMetrics: usingMetrics,
|
|
78
|
+
color: props.color
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Creates availability metrics for a specific AZ
|
|
83
|
+
* @param props
|
|
84
|
+
* @param dimensions
|
|
85
|
+
* @returns
|
|
86
|
+
*/
|
|
87
|
+
static createZonalAvailabilityMetric(props, dimensions) {
|
|
88
|
+
let usingMetrics = {};
|
|
89
|
+
let successKeys = [];
|
|
90
|
+
let faultKeys = [];
|
|
91
|
+
if (props.metricDetails.successMetricNames !== undefined &&
|
|
92
|
+
props.metricType != AvailabilityMetricType_1.AvailabilityMetricType.FAULT_COUNT) {
|
|
93
|
+
props.metricDetails.successMetricNames.forEach((successMetric) => {
|
|
94
|
+
let key = `${props.availabilityZone.substring(props.availabilityZone.length - 1)}_${props.metricDetails.operationName.toLowerCase()}_${props.metricType.toString().toLowerCase()}_${successMetric.toLowerCase()}`;
|
|
95
|
+
successKeys.push(key);
|
|
96
|
+
usingMetrics[key] = new aws_cloudwatch_1.Metric({
|
|
97
|
+
namespace: props.metricDetails.metricNamespace,
|
|
98
|
+
metricName: successMetric,
|
|
99
|
+
unit: props.metricDetails.unit,
|
|
100
|
+
period: props.metricDetails.period,
|
|
101
|
+
statistic: props.metricDetails.alarmStatistic,
|
|
102
|
+
dimensionsMap: dimensions,
|
|
103
|
+
label: successMetric,
|
|
104
|
+
});
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
if (props.metricDetails.faultMetricNames !== undefined &&
|
|
108
|
+
props.metricType != AvailabilityMetricType_1.AvailabilityMetricType.SUCCESS_COUNT) {
|
|
109
|
+
props.metricDetails.faultMetricNames.forEach((faultMetric) => {
|
|
110
|
+
let key = `${props.availabilityZone.substring(props.availabilityZone.length - 1)}_${props.metricDetails.operationName.toLowerCase()}_${props.metricType.toString().toLowerCase()}_${faultMetric.toLowerCase()}`;
|
|
57
111
|
faultKeys.push(key);
|
|
58
112
|
usingMetrics[key] = new aws_cloudwatch_1.Metric({
|
|
59
113
|
namespace: props.metricDetails.metricNamespace,
|
|
@@ -89,6 +143,7 @@ class AvailabilityAndLatencyMetrics {
|
|
|
89
143
|
label: props.label,
|
|
90
144
|
period: props.metricDetails.period,
|
|
91
145
|
usingMetrics: usingMetrics,
|
|
146
|
+
color: props.color
|
|
92
147
|
});
|
|
93
148
|
}
|
|
94
149
|
/**
|
|
@@ -123,6 +178,27 @@ class AvailabilityAndLatencyMetrics {
|
|
|
123
178
|
label: props.label,
|
|
124
179
|
}));
|
|
125
180
|
}
|
|
181
|
+
/**
|
|
182
|
+
* Creates a latency metric with the provided name
|
|
183
|
+
* @param props
|
|
184
|
+
* @param dimensions
|
|
185
|
+
* @returns
|
|
186
|
+
*/
|
|
187
|
+
static createLatencyMetric(props, dimensions) {
|
|
188
|
+
if (!(props.metricName)) {
|
|
189
|
+
throw new Error("You must provide a metric name.");
|
|
190
|
+
}
|
|
191
|
+
return new aws_cloudwatch_1.Metric({
|
|
192
|
+
metricName: props.metricName,
|
|
193
|
+
namespace: props.metricDetails.metricNamespace,
|
|
194
|
+
unit: props.metricDetails.unit,
|
|
195
|
+
period: props.metricDetails.period,
|
|
196
|
+
statistic: props.statistic,
|
|
197
|
+
dimensionsMap: dimensions,
|
|
198
|
+
label: props.label,
|
|
199
|
+
color: props.color
|
|
200
|
+
});
|
|
201
|
+
}
|
|
126
202
|
/**
|
|
127
203
|
* Takes all of the success or failure latency metric names and creates an average of those
|
|
128
204
|
* names, if there's only 1 name, it just returns that metric
|
|
@@ -150,6 +226,7 @@ class AvailabilityAndLatencyMetrics {
|
|
|
150
226
|
label: props.label,
|
|
151
227
|
period: props.metricDetails.period,
|
|
152
228
|
usingMetrics: usingMetrics,
|
|
229
|
+
color: props.color
|
|
153
230
|
});
|
|
154
231
|
}
|
|
155
232
|
}
|
|
@@ -168,22 +245,38 @@ class AvailabilityAndLatencyMetrics {
|
|
|
168
245
|
else {
|
|
169
246
|
let usingMetrics = {};
|
|
170
247
|
latencyMetrics.forEach((metric, index) => {
|
|
171
|
-
let
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
248
|
+
let key = `${props.metricDetails.operationName.toLowerCase()}_${props.metricType.toString().toLowerCase()}_${index}`;
|
|
249
|
+
usingMetrics[key] = metric;
|
|
250
|
+
});
|
|
251
|
+
return new aws_cloudwatch_1.MathExpression({
|
|
252
|
+
expression: Object.keys(usingMetrics).join('+'),
|
|
253
|
+
label: props.label,
|
|
254
|
+
period: props.metricDetails.period,
|
|
255
|
+
usingMetrics: usingMetrics,
|
|
256
|
+
color: props.color
|
|
257
|
+
});
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
static createZonalLatencyCountMetric(props, dimensions) {
|
|
261
|
+
let latencyMetrics = AvailabilityAndLatencyMetrics.createLatencyMetrics(props, dimensions);
|
|
262
|
+
if (latencyMetrics.length == 1) {
|
|
263
|
+
return latencyMetrics[0];
|
|
264
|
+
}
|
|
265
|
+
else {
|
|
266
|
+
let usingMetrics = {};
|
|
267
|
+
latencyMetrics.forEach((metric, index) => {
|
|
268
|
+
let key = `${props.availabilityZone.substring(props.availabilityZone.length - 1)}_${props.metricDetails.operationName.toLowerCase()}_${props.metricType.toString().toLowerCase()}_${index}`;
|
|
269
|
+
usingMetrics[key] = metric;
|
|
178
270
|
});
|
|
179
271
|
return new aws_cloudwatch_1.MathExpression({
|
|
180
272
|
expression: Object.keys(usingMetrics).join('+'),
|
|
181
273
|
label: props.label,
|
|
182
274
|
period: props.metricDetails.period,
|
|
183
275
|
usingMetrics: usingMetrics,
|
|
276
|
+
color: props.color
|
|
184
277
|
});
|
|
185
278
|
}
|
|
186
279
|
}
|
|
187
280
|
}
|
|
188
281
|
exports.AvailabilityAndLatencyMetrics = AvailabilityAndLatencyMetrics;
|
|
189
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AvailabilityAndLatencyMetrics.js","sourceRoot":"","sources":["../../src/metrics/AvailabilityAndLatencyMetrics.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport { IMetric, Metric, MathExpression } from 'aws-cdk-lib/aws-cloudwatch';\nimport { AvailabilityMetricProps } from './props/AvailabilityMetricProps';\nimport { LatencyMetricProps } from './props/LatencyMetricProps';\nimport { AvailabilityMetricType } from '../utilities/AvailabilityMetricType';\nimport { LatencyMetricType } from '../utilities/LatencyMetricType';\n\n/**\n * Class for creating availability and latency metrics that can be used in alarms and graphs\n */\nexport class AvailabilityAndLatencyMetrics {\n\n  /**\n   * General purpose method to create availability metrics\n   * @param props\n   * @param dimensions\n   * @returns\n   */\n  static createAvailabilityMetric(\n    props: AvailabilityMetricProps,\n    dimensions: { [key: string]: string },\n  ): IMetric {\n    let counter: number = 0;\n    let key: string = '';\n\n    let usingMetrics: { [key: string]: IMetric } = {};\n\n    let successKeys: string[] = [];\n    let faultKeys: string[] = [];\n\n    if (\n      props.metricDetails.successMetricNames !== undefined &&\n      props.metricType != AvailabilityMetricType.FAULT_COUNT\n    ) {\n      props.metricDetails.successMetricNames.forEach(\n        (successMetric: string) => {\n          let keyPrefix =\n            (props.keyPrefix === undefined || props.keyPrefix == ''\n              ? ''\n              : props.keyPrefix.toLowerCase() + '_') +\n            props.metricDetails.operationName.toLowerCase() +\n            '_' +\n            successMetric.toLowerCase();\n\n          key = keyPrefix + '_' + counter++;\n          successKeys.push(key);\n\n          usingMetrics[key] = new Metric({\n            namespace: props.metricDetails.metricNamespace,\n            metricName: successMetric,\n            unit: props.metricDetails.unit,\n            period: props.metricDetails.period,\n            statistic: props.metricDetails.alarmStatistic,\n            dimensionsMap: dimensions,\n            label: successMetric,\n          });\n        },\n      );\n    }\n\n    if (\n      props.metricDetails.faultMetricNames !== undefined &&\n      props.metricType != AvailabilityMetricType.SUCCESS_COUNT\n    ) {\n      props.metricDetails.faultMetricNames.forEach((faultMetric) => {\n        let keyPrefix =\n          (props.keyPrefix === undefined || props.keyPrefix == ''\n            ? ''\n            : props.keyPrefix.toLowerCase() + '_') +\n          props.metricDetails.operationName.toLowerCase() +\n          '_' +\n          faultMetric.toLowerCase();\n\n        key = keyPrefix + '_' + counter++;\n        faultKeys.push(key);\n\n        usingMetrics[key] = new Metric({\n          namespace: props.metricDetails.metricNamespace,\n          metricName: faultMetric,\n          unit: props.metricDetails.unit,\n          period: props.metricDetails.period,\n          statistic: props.metricDetails.alarmStatistic,\n          dimensionsMap: dimensions,\n          label: faultMetric,\n        });\n      });\n    }\n\n    let expression: string = '';\n\n    switch (props.metricType) {\n      case AvailabilityMetricType.SUCCESS_RATE:\n        expression = `((${successKeys.join('+')}) / (${successKeys.join('+')}+${faultKeys.join('+')})) * 100`;\n        break;\n      case AvailabilityMetricType.REQUEST_COUNT:\n        expression = `${successKeys.join('+')}+${faultKeys.join('+')}`;\n        break;\n      case AvailabilityMetricType.FAULT_COUNT:\n        expression = `(${faultKeys.join('+')})`;\n        break;\n      case AvailabilityMetricType.FAULT_RATE:\n        expression = `((${faultKeys.join('+')}) / (${successKeys.join('+')}+${faultKeys.join('+')})) * 100`;\n        break;\n      case AvailabilityMetricType.SUCCESS_COUNT:\n        expression = `(${successKeys.join('+')})`;\n        break;\n    }\n\n    return new MathExpression({\n      expression: expression,\n      label: props.label,\n      period: props.metricDetails.period,\n      usingMetrics: usingMetrics,\n    });\n  }\n\n  /**\n   * General purpose method to create latency metrics, the reason this creates an array of metrics while the\n   * equivalent availability metric method doesn't is because in availability, we can just sum the count of different\n   * metric names while for latency we can't sum the count because that's not what's being measured. It allows the\n   * caller to decide if they only want to take the first name, or average all of the names\n   * (like SuccessLatency and BigItemSuccessLatency).\n   *\n   * @param props\n   * @param dimensions\n   * @returns\n   */\n  static createLatencyMetrics(\n    props: LatencyMetricProps,\n    dimensions: { [key: string]: string },\n  ): IMetric[] {\n    let names: string[];\n\n    switch (props.metricType) {\n      default:\n      case LatencyMetricType.SUCCESS_LATENCY:\n        names = props.metricDetails.successMetricNames;\n        break;\n      case LatencyMetricType.FAULT_LATENCY:\n        names = props.metricDetails.faultMetricNames;\n        break;\n    }\n\n    return names.map(\n      (x) =>\n        new Metric({\n          metricName: x,\n          namespace: props.metricDetails.metricNamespace,\n          unit: props.metricDetails.unit,\n          period: props.metricDetails.period,\n          statistic: props.statistic,\n          dimensionsMap: dimensions,\n          label: props.label,\n        }),\n    );\n  }\n\n  /**\n   * Takes all of the success or failure latency metric names and creates an average of those\n   * names, if there's only 1 name, it just returns that metric\n   * @param props\n   * @param dimensions\n   */\n  static createAverageLatencyMetric(\n    props: LatencyMetricProps,\n    dimensions: { [key: string]: string },\n  ): IMetric {\n    let latencyMetrics: IMetric[] =\n      AvailabilityAndLatencyMetrics.createLatencyMetrics(props, dimensions);\n\n    if (latencyMetrics.length == 1) {\n      return latencyMetrics[0];\n    } else {\n      let usingMetrics: { [key: string]: IMetric } = {};\n\n      latencyMetrics.forEach((metric: IMetric, index: number) => {\n        let keyPrefix: string =\n          (props.keyPrefix === undefined || props.keyPrefix == ''\n            ? ''\n            : props.keyPrefix.toLowerCase() + '_') +\n          props.metricDetails.operationName.toLowerCase() +\n          '_' +\n          props.metricType.toString().toLowerCase();\n\n        usingMetrics[keyPrefix + index] = metric;\n      });\n\n      return new MathExpression({\n        expression: `(${Object.keys(usingMetrics).join('+')})/${Object.keys(usingMetrics).length}`,\n        label: props.label,\n        period: props.metricDetails.period,\n        usingMetrics: usingMetrics,\n      });\n    }\n  }\n\n  /**\n   * Creates a count of high latency metrics for either SuccessLatency or FaultLatency, will total\n   * the count of requests that exceed a threshold you define in your statistic, like TC(200:) across\n   * all metric names that are part of either Success or Fault latency.\n   * @param props\n   * @returns\n   */\n  static createLatencyCountMetric(\n    props: LatencyMetricProps,\n    dimensions: { [key: string]: string },\n  ): IMetric {\n    let latencyMetrics: IMetric[] =\n      AvailabilityAndLatencyMetrics.createLatencyMetrics(props, dimensions);\n\n    if (latencyMetrics.length == 1) {\n      return latencyMetrics[0];\n    } else {\n      let usingMetrics: { [key: string]: IMetric } = {};\n\n      latencyMetrics.forEach((metric: IMetric, index: number) => {\n        let keyPrefix: string =\n          (props.keyPrefix === undefined || props.keyPrefix == ''\n            ? ''\n            : props.keyPrefix.toLowerCase() + '_') +\n          props.metricDetails.operationName.toLowerCase() +\n          '_' +\n          props.metricType.toString().toLowerCase();\n\n        usingMetrics[keyPrefix + index] = metric;\n      });\n\n      return new MathExpression({\n        expression: Object.keys(usingMetrics).join('+'),\n        label: props.label,\n        period: props.metricDetails.period,\n        usingMetrics: usingMetrics,\n      });\n    }\n  }\n}\n"]}
|
|
282
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AvailabilityAndLatencyMetrics.js","sourceRoot":"","sources":["../../src/metrics/AvailabilityAndLatencyMetrics.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport { IMetric, Metric, MathExpression } from 'aws-cdk-lib/aws-cloudwatch';\nimport { AvailabilityMetricProps } from './props/AvailabilityMetricProps';\nimport { LatencyMetricProps } from './props/LatencyMetricProps';\nimport { AvailabilityMetricType } from '../utilities/AvailabilityMetricType';\nimport { LatencyMetricType } from '../utilities/LatencyMetricType';\nimport { ZonalAvailabilityMetricProps } from './props/ZonalAvailabilityMetricProps';\nimport { ZonalLatencyMetricProps } from './props/ZonalLatencyMetricProps';\n\n/**\n * Class for creating availability and latency metrics that can be used in alarms and graphs\n */\nexport class AvailabilityAndLatencyMetrics {\n\n  /**\n   * General purpose method to create availability metrics\n   * @param props\n   * @param dimensions\n   * @returns\n   */\n  static createAvailabilityMetric(\n    props: AvailabilityMetricProps,\n    dimensions: { [key: string]: string },\n  ): IMetric {\n    let usingMetrics: { [key: string]: IMetric } = {};\n\n    let successKeys: string[] = [];\n    let faultKeys: string[] = [];\n\n    if (\n      props.metricDetails.successMetricNames !== undefined &&\n      props.metricType != AvailabilityMetricType.FAULT_COUNT\n    ) {\n      props.metricDetails.successMetricNames.forEach((successMetric: string) => {\n          let key: string = `${props.metricDetails.operationName.toLowerCase()}_${props.metricType.toString().toLowerCase()}_${successMetric.toLowerCase()}`;\n\n          successKeys.push(key);\n\n          usingMetrics[key] = new Metric({\n            namespace: props.metricDetails.metricNamespace,\n            metricName: successMetric,\n            unit: props.metricDetails.unit,\n            period: props.metricDetails.period,\n            statistic: props.metricDetails.alarmStatistic,\n            dimensionsMap: dimensions,\n            label: successMetric,\n          });\n        },\n      );\n    }\n\n    if (\n      props.metricDetails.faultMetricNames !== undefined &&\n      props.metricType != AvailabilityMetricType.SUCCESS_COUNT\n    ) {\n      props.metricDetails.faultMetricNames.forEach((faultMetric) => {\n        let key: string = `${props.metricDetails.operationName.toLowerCase()}_${props.metricType.toString().toLowerCase()}_${faultMetric.toLowerCase()}`;\n\n        faultKeys.push(key);\n\n        usingMetrics[key] = new Metric({\n          namespace: props.metricDetails.metricNamespace,\n          metricName: faultMetric,\n          unit: props.metricDetails.unit,\n          period: props.metricDetails.period,\n          statistic: props.metricDetails.alarmStatistic,\n          dimensionsMap: dimensions,\n          label: faultMetric,\n        });\n      });\n    }\n\n    let expression: string = '';\n\n    switch (props.metricType) {\n      case AvailabilityMetricType.SUCCESS_RATE:\n        expression = `((${successKeys.join('+')}) / (${successKeys.join('+')}+${faultKeys.join('+')})) * 100`;\n        break;\n      case AvailabilityMetricType.REQUEST_COUNT:\n        expression = `${successKeys.join('+')}+${faultKeys.join('+')}`;\n        break;\n      case AvailabilityMetricType.FAULT_COUNT:\n        expression = `(${faultKeys.join('+')})`;\n        break;\n      case AvailabilityMetricType.FAULT_RATE:\n        expression = `((${faultKeys.join('+')}) / (${successKeys.join('+')}+${faultKeys.join('+')})) * 100`;\n        break;\n      case AvailabilityMetricType.SUCCESS_COUNT:\n        expression = `(${successKeys.join('+')})`;\n        break;\n    }\n\n    return new MathExpression({\n      expression: expression,\n      label: props.label,\n      period: props.metricDetails.period,\n      usingMetrics: usingMetrics,\n      color: props.color\n    });\n  }\n\n  /**\n   *  Creates availability metrics for a specific AZ\n   * @param props \n   * @param dimensions \n   * @returns \n   */\n  static createZonalAvailabilityMetric(\n    props: ZonalAvailabilityMetricProps,\n    dimensions: { [key: string]: string },\n  ): IMetric {\n    let usingMetrics: { [key: string]: IMetric } = {};\n\n    let successKeys: string[] = [];\n    let faultKeys: string[] = [];\n\n    if (\n      props.metricDetails.successMetricNames !== undefined &&\n      props.metricType != AvailabilityMetricType.FAULT_COUNT\n    ) {\n      props.metricDetails.successMetricNames.forEach((successMetric: string) => {\n          let key: string = `${props.availabilityZone.substring(props.availabilityZone.length - 1)}_${props.metricDetails.operationName.toLowerCase()}_${props.metricType.toString().toLowerCase()}_${successMetric.toLowerCase()}`;\n\n          successKeys.push(key);\n\n          usingMetrics[key] = new Metric({\n            namespace: props.metricDetails.metricNamespace,\n            metricName: successMetric,\n            unit: props.metricDetails.unit,\n            period: props.metricDetails.period,\n            statistic: props.metricDetails.alarmStatistic,\n            dimensionsMap: dimensions,\n            label: successMetric,\n          });\n        },\n      );\n    }\n\n    if (\n      props.metricDetails.faultMetricNames !== undefined &&\n      props.metricType != AvailabilityMetricType.SUCCESS_COUNT\n    ) {\n      props.metricDetails.faultMetricNames.forEach((faultMetric) => {\n        let key: string = `${props.availabilityZone.substring(props.availabilityZone.length - 1)}_${props.metricDetails.operationName.toLowerCase()}_${props.metricType.toString().toLowerCase()}_${faultMetric.toLowerCase()}`;\n\n        faultKeys.push(key);\n\n        usingMetrics[key] = new Metric({\n          namespace: props.metricDetails.metricNamespace,\n          metricName: faultMetric,\n          unit: props.metricDetails.unit,\n          period: props.metricDetails.period,\n          statistic: props.metricDetails.alarmStatistic,\n          dimensionsMap: dimensions,\n          label: faultMetric,\n        });\n      });\n    }\n\n    let expression: string = '';\n\n    switch (props.metricType) {\n      case AvailabilityMetricType.SUCCESS_RATE:\n        expression = `((${successKeys.join('+')}) / (${successKeys.join('+')}+${faultKeys.join('+')})) * 100`;\n        break;\n      case AvailabilityMetricType.REQUEST_COUNT:\n        expression = `${successKeys.join('+')}+${faultKeys.join('+')}`;\n        break;\n      case AvailabilityMetricType.FAULT_COUNT:\n        expression = `(${faultKeys.join('+')})`;\n        break;\n      case AvailabilityMetricType.FAULT_RATE:\n        expression = `((${faultKeys.join('+')}) / (${successKeys.join('+')}+${faultKeys.join('+')})) * 100`;\n        break;\n      case AvailabilityMetricType.SUCCESS_COUNT:\n        expression = `(${successKeys.join('+')})`;\n        break;\n    }\n\n    return new MathExpression({\n      expression: expression,\n      label: props.label,\n      period: props.metricDetails.period,\n      usingMetrics: usingMetrics,\n      color: props.color\n    });\n  }\n\n  /**\n   * General purpose method to create latency metrics, the reason this creates an array of metrics while the\n   * equivalent availability metric method doesn't is because in availability, we can just sum the count of different\n   * metric names while for latency we can't sum the count because that's not what's being measured. It allows the\n   * caller to decide if they only want to take the first name, or average all of the names\n   * (like SuccessLatency and BigItemSuccessLatency).\n   *\n   * @param props\n   * @param dimensions\n   * @returns\n   */\n  static createLatencyMetrics(\n    props: LatencyMetricProps,\n    dimensions: { [key: string]: string },\n  ): IMetric[] {\n    let names: string[];\n\n    switch (props.metricType) {\n      default:\n      case LatencyMetricType.SUCCESS_LATENCY:\n        names = props.metricDetails.successMetricNames;\n        break;\n      case LatencyMetricType.FAULT_LATENCY:\n        names = props.metricDetails.faultMetricNames;\n        break;\n    }\n\n    return names.map(\n      (x) =>\n        new Metric({\n          metricName: x,\n          namespace: props.metricDetails.metricNamespace,\n          unit: props.metricDetails.unit,\n          period: props.metricDetails.period,\n          statistic: props.statistic,\n          dimensionsMap: dimensions,\n          label: props.label,\n        }),\n    );\n  }\n\n  /**\n   * Creates a latency metric with the provided name\n   * @param props \n   * @param dimensions \n   * @returns \n   */\n  static createLatencyMetric(\n    props: LatencyMetricProps,\n    dimensions: { [key: string]: string }\n  ): IMetric {\n    if (!(props.metricName)) {\n      throw new Error(\"You must provide a metric name.\");\n    }\n\n    return new Metric({\n      metricName: props.metricName!,\n      namespace: props.metricDetails.metricNamespace,\n      unit: props.metricDetails.unit,\n      period: props.metricDetails.period,\n      statistic: props.statistic,\n      dimensionsMap: dimensions,\n      label: props.label,\n      color: props.color\n    });\n  }\n\n  /**\n   * Takes all of the success or failure latency metric names and creates an average of those\n   * names, if there's only 1 name, it just returns that metric\n   * @param props\n   * @param dimensions\n   */\n  static createAverageLatencyMetric(\n    props: LatencyMetricProps,\n    dimensions: { [key: string]: string },\n  ): IMetric {\n    let latencyMetrics: IMetric[] =\n      AvailabilityAndLatencyMetrics.createLatencyMetrics(props, dimensions);\n\n    if (latencyMetrics.length == 1) {\n      return latencyMetrics[0];\n    } else {\n      let usingMetrics: { [key: string]: IMetric } = {};\n\n      latencyMetrics.forEach((metric: IMetric, index: number) => {\n        let keyPrefix: string =\n          (props.keyPrefix === undefined || props.keyPrefix == ''\n            ? ''\n            : props.keyPrefix.toLowerCase() + '_') +\n          props.metricDetails.operationName.toLowerCase() +\n          '_' +\n          props.metricType.toString().toLowerCase();\n\n        usingMetrics[keyPrefix + index] = metric;\n      });\n\n      return new MathExpression({\n        expression: `(${Object.keys(usingMetrics).join('+')})/${Object.keys(usingMetrics).length}`,\n        label: props.label,\n        period: props.metricDetails.period,\n        usingMetrics: usingMetrics,\n        color: props.color\n      });\n    }\n  }\n\n  /**\n   * Creates a count of high latency metrics for either SuccessLatency or FaultLatency, will total\n   * the count of requests that exceed a threshold you define in your statistic, like TC(200:) across\n   * all metric names that are part of either Success or Fault latency.\n   * @param props\n   * @returns\n   */\n  static createLatencyCountMetric(\n    props: LatencyMetricProps,\n    dimensions: { [key: string]: string },\n  ): IMetric {\n    let latencyMetrics: IMetric[] =\n      AvailabilityAndLatencyMetrics.createLatencyMetrics(props, dimensions);\n\n    if (latencyMetrics.length == 1) {\n      return latencyMetrics[0];\n    } else {\n      let usingMetrics: { [key: string]: IMetric } = {};\n\n      latencyMetrics.forEach((metric: IMetric, index: number) => {\n        let key: string = `${props.metricDetails.operationName.toLowerCase()}_${props.metricType.toString().toLowerCase()}_${index}`;\n        usingMetrics[key] = metric;\n      });\n\n      return new MathExpression({\n        expression: Object.keys(usingMetrics).join('+'),\n        label: props.label,\n        period: props.metricDetails.period,\n        usingMetrics: usingMetrics,\n        color: props.color\n      });\n    }\n  }\n\n  static createZonalLatencyCountMetric(\n    props: ZonalLatencyMetricProps,\n    dimensions: { [key: string]: string },\n  ): IMetric {\n    let latencyMetrics: IMetric[] =\n      AvailabilityAndLatencyMetrics.createLatencyMetrics(props, dimensions);\n\n    if (latencyMetrics.length == 1) {\n      return latencyMetrics[0];\n    } else {\n      let usingMetrics: { [key: string]: IMetric } = {};\n\n      latencyMetrics.forEach((metric: IMetric, index: number) => {\n        let key: string = `${props.availabilityZone.substring(props.availabilityZone.length - 1)}_${props.metricDetails.operationName.toLowerCase()}_${props.metricType.toString().toLowerCase()}_${index}`;\n        usingMetrics[key] = metric;\n      });\n\n      return new MathExpression({\n        expression: Object.keys(usingMetrics).join('+'),\n        label: props.label,\n        period: props.metricDetails.period,\n        usingMetrics: usingMetrics,\n        color: props.color\n      });\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { CfnNatGateway } from "aws-cdk-lib/aws-ec2";
|
|
2
|
+
import { IAlarm, IMetric, IWidget } from "aws-cdk-lib/aws-cloudwatch";
|
|
3
|
+
import { Duration } from "aws-cdk-lib";
|
|
4
|
+
import { IConstruct } from "constructs";
|
|
5
|
+
import { IAvailabilityZoneMapper } from "../azmapper/IAvailabilityZoneMapper";
|
|
6
|
+
import { PacketLossOutlierAlgorithm } from "../outlier-detection/PacketLossOutlierAlgorithm";
|
|
7
|
+
/**
|
|
8
|
+
* Provides functions for getting CloudWatch metrics and alarms for NAT Gateways.
|
|
9
|
+
*/
|
|
10
|
+
export declare class NatGatewayMetrics {
|
|
11
|
+
/**
|
|
12
|
+
* Gets the count of packet drops for all NAT Gateways that belong to the provided AZ
|
|
13
|
+
* @param natgws
|
|
14
|
+
* @param availabilityZoneId
|
|
15
|
+
* @param period
|
|
16
|
+
* @returns
|
|
17
|
+
*/
|
|
18
|
+
static getDroppedPacketCountMetricForAZ(natgws: CfnNatGateway[], availabilityZoneId: string, period: Duration, prefix?: string, color?: string): IMetric;
|
|
19
|
+
/**
|
|
20
|
+
* Get the packet drop rate for all NAT Gateways that belong to the provided AZ
|
|
21
|
+
* @param natgws
|
|
22
|
+
* @param availabilityZoneId
|
|
23
|
+
* @param period
|
|
24
|
+
* @returns Percent of packet drops like 52%
|
|
25
|
+
*/
|
|
26
|
+
static getDroppedPacketRateMetricForAZ(natgws: CfnNatGateway[], availabilityZoneId: string, period: Duration, prefix?: string, color?: string): IMetric;
|
|
27
|
+
/**
|
|
28
|
+
* Get the packet count for all NAT Gateways that belong to the provided AZ
|
|
29
|
+
* @param natgws
|
|
30
|
+
* @param availabilityZoneId
|
|
31
|
+
* @param period
|
|
32
|
+
* @returns
|
|
33
|
+
*/
|
|
34
|
+
static getTotalPacketCountMetricForAZ(natgws: CfnNatGateway[], availabilityZoneId: string, period: Duration, prefix?: string, color?: string): IMetric;
|
|
35
|
+
/**
|
|
36
|
+
* Returns an alarm indicating if the quantity of packet drops in a single AZ across all NAT Gateways in that
|
|
37
|
+
* AZ exceeds a threshold compared to all packet loss across all AZs.
|
|
38
|
+
*
|
|
39
|
+
* For example:
|
|
40
|
+
*
|
|
41
|
+
* A = 150 packets
|
|
42
|
+
* B = 175 packets
|
|
43
|
+
* C = 160 packets
|
|
44
|
+
*
|
|
45
|
+
* And the selected AZ is "A", then the calculation is 150 / (150 + 175 + 160).
|
|
46
|
+
*
|
|
47
|
+
* @param scope
|
|
48
|
+
* @param natgws
|
|
49
|
+
* @param availabilityZoneId
|
|
50
|
+
* @param availabilityZone
|
|
51
|
+
* @param threshold
|
|
52
|
+
* @param period
|
|
53
|
+
* @param evaluationPeriods
|
|
54
|
+
* @param datapointsToAlarm
|
|
55
|
+
* @returns
|
|
56
|
+
*/
|
|
57
|
+
static isAZAnOutlierForPacketLossNATGW(scope: IConstruct, natgws: {
|
|
58
|
+
[key: string]: CfnNatGateway[];
|
|
59
|
+
}, algorithm: PacketLossOutlierAlgorithm, availabilityZone: string, azMapper: IAvailabilityZoneMapper, threshold: number, period: Duration, evaluationPeriods: number, datapointsToAlarm: number): IAlarm;
|
|
60
|
+
/**
|
|
61
|
+
* Creates an alarm to determine is the packet loss rate in a single AZ across all NAT Gateways provided
|
|
62
|
+
* for that AZ exceed the provided threshold.
|
|
63
|
+
* @param scope
|
|
64
|
+
* @param natgws
|
|
65
|
+
* @param availabilityZoneId
|
|
66
|
+
* @param availabilityZone
|
|
67
|
+
* @param threshold
|
|
68
|
+
* @param period
|
|
69
|
+
* @param evaluationPeriods
|
|
70
|
+
* @param datapointsToAlarm
|
|
71
|
+
* @returns
|
|
72
|
+
*/
|
|
73
|
+
static isThereAnAZPacketLossImpactNATGW(scope: IConstruct, natgws: CfnNatGateway[], availabilityZoneId: string, availabilityZone: string, threshold: number, period: Duration, evaluationPeriods: number, datapointsToAlarm: number): IAlarm;
|
|
74
|
+
/**
|
|
75
|
+
* Gets the count of all packets from all NAT Gateways in each provided Availability Zone.
|
|
76
|
+
* @param natgws
|
|
77
|
+
* @param azMapper
|
|
78
|
+
* @param period
|
|
79
|
+
* @returns
|
|
80
|
+
*/
|
|
81
|
+
static getTotalPacketCountForEveryAZ(natgws: {
|
|
82
|
+
[key: string]: CfnNatGateway[];
|
|
83
|
+
}, azMapper: IAvailabilityZoneMapper, period: Duration): {
|
|
84
|
+
[key: string]: IMetric;
|
|
85
|
+
};
|
|
86
|
+
/**
|
|
87
|
+
* Gets the count of packet drops from all NAT Gateways in each provided Availability Zone.
|
|
88
|
+
* @param natgws
|
|
89
|
+
* @param azMapper
|
|
90
|
+
* @param period
|
|
91
|
+
* @returns
|
|
92
|
+
*/
|
|
93
|
+
static getTotalPacketDropsForEveryAZ(natgws: {
|
|
94
|
+
[key: string]: CfnNatGateway[];
|
|
95
|
+
}, azMapper: IAvailabilityZoneMapper, period: Duration): {
|
|
96
|
+
[key: string]: IMetric;
|
|
97
|
+
};
|
|
98
|
+
/**
|
|
99
|
+
* Gets the packet drop rate from all NAT Gateways in each provided Availability Zone.
|
|
100
|
+
* @param natgws
|
|
101
|
+
* @param azMapper
|
|
102
|
+
* @param period
|
|
103
|
+
* @returns
|
|
104
|
+
*/
|
|
105
|
+
static getTotalPacketDropRateForEveryAZ(natgws: {
|
|
106
|
+
[key: string]: CfnNatGateway[];
|
|
107
|
+
}, azMapper: IAvailabilityZoneMapper, period: Duration): {
|
|
108
|
+
[key: string]: IMetric;
|
|
109
|
+
};
|
|
110
|
+
static generateNatGatewayWidgets(natgws: {
|
|
111
|
+
[key: string]: CfnNatGateway[];
|
|
112
|
+
}, azMapper: IAvailabilityZoneMapper, period: Duration, packetDropRateThreshold: number): IWidget[];
|
|
113
|
+
}
|