@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.
Files changed (100) hide show
  1. package/.jsii +374 -147
  2. package/API.md +292 -100
  3. package/README.md +21 -14
  4. package/cdk.json +1 -1
  5. package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.d.ts +7 -7
  6. package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.js +35 -35
  7. package/lib/alarmsandrules/BaseOperationRegionalAlarmsAndRules.js +2 -2
  8. package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.d.ts +6 -15
  9. package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.js +2 -10
  10. package/lib/alarmsandrules/CanaryOperationZonalAlarmsAndRules.d.ts +11 -3
  11. package/lib/alarmsandrules/CanaryOperationZonalAlarmsAndRules.js +24 -13
  12. package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.d.ts +0 -8
  13. package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.js +1 -1
  14. package/lib/alarmsandrules/IOperationAlarmsAndRules.d.ts +19 -27
  15. package/lib/alarmsandrules/IOperationAlarmsAndRules.js +1 -1
  16. package/lib/alarmsandrules/IServerSideOperationRegionalAlarmsAndRules.js +1 -1
  17. package/lib/alarmsandrules/IServiceAlarmsAndRules.d.ts +0 -8
  18. package/lib/alarmsandrules/IServiceAlarmsAndRules.js +1 -1
  19. package/lib/alarmsandrules/OperationAlarmsAndRules.d.ts +14 -22
  20. package/lib/alarmsandrules/OperationAlarmsAndRules.js +51 -71
  21. package/lib/alarmsandrules/ServerSideOperationRegionalAlarmsAndRules.d.ts +5 -5
  22. package/lib/alarmsandrules/ServerSideOperationRegionalAlarmsAndRules.js +2 -3
  23. package/lib/alarmsandrules/ServerSideOperationZonalAlarmsAndRules.d.ts +21 -13
  24. package/lib/alarmsandrules/ServerSideOperationZonalAlarmsAndRules.js +43 -29
  25. package/lib/alarmsandrules/ServiceAlarmsAndRules.d.ts +0 -2
  26. package/lib/alarmsandrules/ServiceAlarmsAndRules.js +61 -39
  27. package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.d.ts +6 -44
  28. package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.js +1 -1
  29. package/lib/alarmsandrules/props/OperationAlarmsAndRulesProps.d.ts +28 -7
  30. package/lib/alarmsandrules/props/OperationAlarmsAndRulesProps.js +1 -1
  31. package/lib/azmapper/AvailabilityZoneMapper.js +4 -3
  32. package/lib/basic_observability/BasicServiceDashboard.d.ts +0 -3
  33. package/lib/basic_observability/BasicServiceDashboard.js +24 -112
  34. package/lib/basic_observability/BasicServiceMultiAZObservability.d.ts +8 -9
  35. package/lib/basic_observability/BasicServiceMultiAZObservability.js +100 -312
  36. package/lib/basic_observability/props/ApplicationLoadBalancerDetectionProps.d.ts +50 -0
  37. package/lib/basic_observability/props/ApplicationLoadBalancerDetectionProps.js +3 -0
  38. package/lib/basic_observability/props/BasicServiceDashboardProps.d.ts +27 -13
  39. package/lib/basic_observability/props/BasicServiceDashboardProps.js +1 -1
  40. package/lib/basic_observability/props/BasicServiceMultiAZObservabilityProps.d.ts +10 -38
  41. package/lib/basic_observability/props/BasicServiceMultiAZObservabilityProps.js +1 -1
  42. package/lib/basic_observability/props/NatGatewayDetectionProps.d.ts +31 -0
  43. package/lib/basic_observability/props/NatGatewayDetectionProps.js +3 -0
  44. package/lib/canaries/CanaryFunction.js +7 -6
  45. package/lib/canaries/src/canary.zip +0 -0
  46. package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.d.ts +2 -6
  47. package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.js +440 -506
  48. package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.d.ts +0 -1
  49. package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.js +56 -113
  50. package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.d.ts +3 -66
  51. package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.js +1 -1
  52. package/lib/dashboards/props/OperationAvailabilityWidgetProps.d.ts +7 -2
  53. package/lib/dashboards/props/OperationAvailabilityWidgetProps.js +1 -1
  54. package/lib/dashboards/props/OperationLatencyWidgetProps.d.ts +7 -2
  55. package/lib/dashboards/props/OperationLatencyWidgetProps.js +1 -1
  56. package/lib/index.d.ts +5 -0
  57. package/lib/index.js +8 -2
  58. package/lib/metrics/ApplicationLoadBalancerMetrics.d.ts +72 -4
  59. package/lib/metrics/ApplicationLoadBalancerMetrics.js +671 -33
  60. package/lib/metrics/AvailabilityAndLatencyMetrics.d.ts +23 -0
  61. package/lib/metrics/AvailabilityAndLatencyMetrics.js +117 -24
  62. package/lib/metrics/NatGatewayMetrics.d.ts +113 -0
  63. package/lib/metrics/NatGatewayMetrics.js +357 -0
  64. package/lib/metrics/RegionalLatencyMetrics.d.ts +1 -1
  65. package/lib/metrics/RegionalLatencyMetrics.js +27 -20
  66. package/lib/metrics/ZonalAvailabilityMetrics.d.ts +2 -8
  67. package/lib/metrics/ZonalAvailabilityMetrics.js +10 -25
  68. package/lib/metrics/ZonalLatencyMetrics.d.ts +2 -1
  69. package/lib/metrics/ZonalLatencyMetrics.js +33 -23
  70. package/lib/metrics/props/AvailabilityAndLatencyMetricProps.d.ts +4 -0
  71. package/lib/metrics/props/AvailabilityAndLatencyMetricProps.js +1 -1
  72. package/lib/metrics/props/LatencyMetricProps.d.ts +6 -0
  73. package/lib/metrics/props/LatencyMetricProps.js +1 -1
  74. package/lib/metrics/props/ZonalAvailabilityMetricProps.d.ts +4 -0
  75. package/lib/metrics/props/ZonalAvailabilityMetricProps.js +1 -1
  76. package/lib/metrics/props/ZonalLatencyMetricProps.d.ts +4 -0
  77. package/lib/metrics/props/ZonalLatencyMetricProps.js +1 -1
  78. package/lib/monitoring/src/monitoring-layer.zip +0 -0
  79. package/lib/outlier-detection/ApplicationLoadBalancerAvailabilityOutlierAlgorithm.d.ts +10 -0
  80. package/lib/outlier-detection/ApplicationLoadBalancerAvailabilityOutlierAlgorithm.js +15 -0
  81. package/lib/outlier-detection/ApplicationLoadBalancerLatencyOutlierAlgorithm.d.ts +18 -0
  82. package/lib/outlier-detection/ApplicationLoadBalancerLatencyOutlierAlgorithm.js +23 -0
  83. package/lib/outlier-detection/OutlierDetectionFunction.js +6 -5
  84. package/lib/outlier-detection/PacketLossOutlierAlgorithm.d.ts +10 -0
  85. package/lib/outlier-detection/PacketLossOutlierAlgorithm.js +15 -0
  86. package/lib/outlier-detection/src/outlier-detection.zip +0 -0
  87. package/lib/outlier-detection/src/scipy-layer.zip +0 -0
  88. package/lib/services/CanaryMetrics.js +1 -1
  89. package/lib/services/CanaryTestMetricsOverride.js +1 -1
  90. package/lib/services/ContributorInsightRuleDetails.js +1 -1
  91. package/lib/services/InstrumentedServiceMultiAZObservability.d.ts +10 -0
  92. package/lib/services/InstrumentedServiceMultiAZObservability.js +188 -194
  93. package/lib/services/Operation.js +1 -1
  94. package/lib/services/OperationMetricDetails.js +1 -1
  95. package/lib/services/Service.js +1 -1
  96. package/lib/services/ServiceMetricDetails.js +1 -1
  97. package/lib/services/props/MetricDimensions.js +1 -1
  98. package/lib/utilities/MetricsHelper.d.ts +15 -10
  99. package/lib/utilities/MetricsHelper.js +19 -11
  100. 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 keyPrefix = (props.keyPrefix === undefined || props.keyPrefix == ''
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 keyPrefix = (props.keyPrefix === undefined || props.keyPrefix == ''
51
- ? ''
52
- : props.keyPrefix.toLowerCase() + '_') +
53
- props.metricDetails.operationName.toLowerCase() +
54
- '_' +
55
- faultMetric.toLowerCase();
56
- key = keyPrefix + '_' + counter++;
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 keyPrefix = (props.keyPrefix === undefined || props.keyPrefix == ''
172
- ? ''
173
- : props.keyPrefix.toLowerCase() + '_') +
174
- props.metricDetails.operationName.toLowerCase() +
175
- '_' +
176
- props.metricType.toString().toLowerCase();
177
- usingMetrics[keyPrefix + index] = metric;
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
+ }