@cdklabs/multi-az-observability 0.0.1-alpha.2 → 0.0.1-alpha.21
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 +372 -115
- package/API.md +292 -74
- package/README.md +21 -14
- package/cdk.json +1 -1
- package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.d.ts +6 -6
- package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.js +31 -28
- package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.d.ts +0 -4
- package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.js +6 -5
- package/lib/alarmsandrules/CanaryOperationZonalAlarmsAndRules.js +8 -6
- package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.d.ts +0 -4
- package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.js +1 -1
- package/lib/alarmsandrules/OperationAlarmsAndRules.js +10 -12
- package/lib/alarmsandrules/ServerSideOperationZonalAlarmsAndRules.js +14 -12
- package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.d.ts +2 -2
- package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.js +1 -1
- package/lib/azmapper/AvailabilityZoneMapper.js +4 -3
- package/lib/basic_observability/BasicServiceDashboard.d.ts +1 -2
- package/lib/basic_observability/BasicServiceDashboard.js +58 -78
- 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 +3 -6
- package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.js +359 -498
- package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.d.ts +0 -1
- package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.js +56 -113
- package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.d.ts +4 -8
- 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 +65 -4
- package/lib/metrics/ApplicationLoadBalancerMetrics.js +629 -40
- package/lib/metrics/AvailabilityAndLatencyMetrics.d.ts +23 -0
- package/lib/metrics/AvailabilityAndLatencyMetrics.js +115 -24
- package/lib/metrics/NatGatewayMetrics.d.ts +110 -0
- package/lib/metrics/NatGatewayMetrics.js +300 -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.js +3 -3
- 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 +14 -10
- package/lib/utilities/MetricsHelper.js +18 -11
- package/package.json +8 -8
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { IApplicationLoadBalancer } from "aws-cdk-lib/aws-elasticloadbalancingv2";
|
|
2
|
+
import { ApplicationLoadBalancerAvailabilityOutlierAlgorithm } from "../../outlier-detection/ApplicationLoadBalancerAvailabilityOutlierAlgorithm";
|
|
3
|
+
import { ApplicationLoadBalancerLatencyOutlierAlgorithm } from "../../outlier-detection/ApplicationLoadBalancerLatencyOutlierAlgorithm";
|
|
4
|
+
/**
|
|
5
|
+
* The properties for performing zonal impact detection with ALB(s).
|
|
6
|
+
*/
|
|
7
|
+
export interface ApplicationLoadBalancerDetectionProps {
|
|
8
|
+
/**
|
|
9
|
+
* The application load balancers to collect metrics from.
|
|
10
|
+
*/
|
|
11
|
+
readonly applicationLoadBalancers: IApplicationLoadBalancer[];
|
|
12
|
+
/**
|
|
13
|
+
* The percentage of faults for a single ALB to consider an AZ
|
|
14
|
+
* to be unhealthy, a number between 0 and 100. This should align with your availability goal. For example
|
|
15
|
+
* 1% or 5%, provided as 1 or 5.
|
|
16
|
+
*/
|
|
17
|
+
readonly faultCountPercentThreshold: number;
|
|
18
|
+
/**
|
|
19
|
+
* The threshold in milliseconds for ALB targets whose responses are slower than this
|
|
20
|
+
* value at the specified percentile statistic.
|
|
21
|
+
*/
|
|
22
|
+
readonly latencyThreshold: number;
|
|
23
|
+
/**
|
|
24
|
+
* The statistic used to measure target response latency, like p99,
|
|
25
|
+
* which can be specified using Stats.percentile(99) or "p99".
|
|
26
|
+
*/
|
|
27
|
+
readonly latencyStatistic: string;
|
|
28
|
+
/**
|
|
29
|
+
* The method used to determine if an AZ is an outlier for latency for Application Load Balancer metrics.
|
|
30
|
+
* @default Z_SCORE
|
|
31
|
+
*/
|
|
32
|
+
readonly latencyOutlierAlgorithm?: ApplicationLoadBalancerLatencyOutlierAlgorithm;
|
|
33
|
+
/**
|
|
34
|
+
* The method used to determine if an AZ is an outlier for availability for Application Load Balancer metrics.
|
|
35
|
+
* @default STATIC
|
|
36
|
+
*/
|
|
37
|
+
readonly availabilityOutlierAlgorithm?: ApplicationLoadBalancerAvailabilityOutlierAlgorithm;
|
|
38
|
+
/**
|
|
39
|
+
* The threshold for the outlier detection algorithm.
|
|
40
|
+
*
|
|
41
|
+
* @default "This depends on the algorithm used. STATIC: 66"
|
|
42
|
+
*/
|
|
43
|
+
readonly availabilityOutlierThreshold?: number;
|
|
44
|
+
/**
|
|
45
|
+
* The threshold for the outlier detection algorithm.
|
|
46
|
+
*
|
|
47
|
+
* @default "This depends on the algorithm used. STATIC: 66. Z_SCORE: 3."
|
|
48
|
+
*/
|
|
49
|
+
readonly latencyOutlierThreshold?: number;
|
|
50
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJEZXRlY3Rpb25Qcm9wcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iYXNpY19vYnNlcnZhYmlsaXR5L3Byb3BzL0FwcGxpY2F0aW9uTG9hZEJhbGFuY2VyRGV0ZWN0aW9uUHJvcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElBcHBsaWNhdGlvbkxvYWRCYWxhbmNlciB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtZWxhc3RpY2xvYWRiYWxhbmNpbmd2MlwiO1xuaW1wb3J0IHsgQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJBdmFpbGFiaWxpdHlPdXRsaWVyQWxnb3JpdGhtIH0gZnJvbSBcIi4uLy4uL291dGxpZXItZGV0ZWN0aW9uL0FwcGxpY2F0aW9uTG9hZEJhbGFuY2VyQXZhaWxhYmlsaXR5T3V0bGllckFsZ29yaXRobVwiO1xuaW1wb3J0IHsgQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJMYXRlbmN5T3V0bGllckFsZ29yaXRobSB9IGZyb20gXCIuLi8uLi9vdXRsaWVyLWRldGVjdGlvbi9BcHBsaWNhdGlvbkxvYWRCYWxhbmNlckxhdGVuY3lPdXRsaWVyQWxnb3JpdGhtXCI7XG5cbi8qKlxuICogVGhlIHByb3BlcnRpZXMgZm9yIHBlcmZvcm1pbmcgem9uYWwgaW1wYWN0IGRldGVjdGlvbiB3aXRoIEFMQihzKS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBcHBsaWNhdGlvbkxvYWRCYWxhbmNlckRldGVjdGlvblByb3BzIHtcblxuICAvKipcbiAgICogVGhlIGFwcGxpY2F0aW9uIGxvYWQgYmFsYW5jZXJzIHRvIGNvbGxlY3QgbWV0cmljcyBmcm9tLlxuICAgKi9cbiAgcmVhZG9ubHkgYXBwbGljYXRpb25Mb2FkQmFsYW5jZXJzOiBJQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJbXTtcblxuICAvKipcbiAgICogVGhlIHBlcmNlbnRhZ2Ugb2YgZmF1bHRzIGZvciBhIHNpbmdsZSBBTEIgdG8gY29uc2lkZXIgYW4gQVpcbiAgICogdG8gYmUgdW5oZWFsdGh5LCBhIG51bWJlciBiZXR3ZWVuIDAgYW5kIDEwMC4gVGhpcyBzaG91bGQgYWxpZ24gd2l0aCB5b3VyIGF2YWlsYWJpbGl0eSBnb2FsLiBGb3IgZXhhbXBsZVxuICAgKiAxJSBvciA1JSwgcHJvdmlkZWQgYXMgMSBvciA1LlxuICAgKi9cbiAgcmVhZG9ubHkgZmF1bHRDb3VudFBlcmNlbnRUaHJlc2hvbGQ6IG51bWJlcjtcblxuICAvKipcbiAgICogVGhlIHRocmVzaG9sZCBpbiBtaWxsaXNlY29uZHMgZm9yIEFMQiB0YXJnZXRzIHdob3NlIHJlc3BvbnNlcyBhcmUgc2xvd2VyIHRoYW4gdGhpc1xuICAgKiB2YWx1ZSBhdCB0aGUgc3BlY2lmaWVkIHBlcmNlbnRpbGUgc3RhdGlzdGljLlxuICAgKi9cbiAgcmVhZG9ubHkgbGF0ZW5jeVRocmVzaG9sZDogbnVtYmVyO1xuICBcbiAgLyoqXG4gICAqIFRoZSBzdGF0aXN0aWMgdXNlZCB0byBtZWFzdXJlIHRhcmdldCByZXNwb25zZSBsYXRlbmN5LCBsaWtlIHA5OSwgXG4gICAqIHdoaWNoIGNhbiBiZSBzcGVjaWZpZWQgdXNpbmcgU3RhdHMucGVyY2VudGlsZSg5OSkgb3IgXCJwOTlcIi5cbiAgICovXG4gIHJlYWRvbmx5IGxhdGVuY3lTdGF0aXN0aWM6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIG1ldGhvZCB1c2VkIHRvIGRldGVybWluZSBpZiBhbiBBWiBpcyBhbiBvdXRsaWVyIGZvciBsYXRlbmN5IGZvciBBcHBsaWNhdGlvbiBMb2FkIEJhbGFuY2VyIG1ldHJpY3MuXG4gICAqIEBkZWZhdWx0IFpfU0NPUkVcbiAgICovXG4gIHJlYWRvbmx5IGxhdGVuY3lPdXRsaWVyQWxnb3JpdGhtPzogQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJMYXRlbmN5T3V0bGllckFsZ29yaXRobTtcblxuICAvKipcbiAgICogVGhlIG1ldGhvZCB1c2VkIHRvIGRldGVybWluZSBpZiBhbiBBWiBpcyBhbiBvdXRsaWVyIGZvciBhdmFpbGFiaWxpdHkgZm9yIEFwcGxpY2F0aW9uIExvYWQgQmFsYW5jZXIgbWV0cmljcy5cbiAgICogQGRlZmF1bHQgU1RBVElDXG4gICAqL1xuICByZWFkb25seSBhdmFpbGFiaWxpdHlPdXRsaWVyQWxnb3JpdGhtPzogQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJBdmFpbGFiaWxpdHlPdXRsaWVyQWxnb3JpdGhtO1xuXG4gIC8qKlxuICAgKiBUaGUgdGhyZXNob2xkIGZvciB0aGUgb3V0bGllciBkZXRlY3Rpb24gYWxnb3JpdGhtLlxuICAgKiBcbiAgICogQGRlZmF1bHQgXCJUaGlzIGRlcGVuZHMgb24gdGhlIGFsZ29yaXRobSB1c2VkLiBTVEFUSUM6IDY2XCJcbiAgICovXG4gIHJlYWRvbmx5IGF2YWlsYWJpbGl0eU91dGxpZXJUaHJlc2hvbGQ/OiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIFRoZSB0aHJlc2hvbGQgZm9yIHRoZSBvdXRsaWVyIGRldGVjdGlvbiBhbGdvcml0aG0uXG4gICAqIFxuICAgKiBAZGVmYXVsdCBcIlRoaXMgZGVwZW5kcyBvbiB0aGUgYWxnb3JpdGhtIHVzZWQuIFNUQVRJQzogNjYuIFpfU0NPUkU6IDMuXCJcbiAgICovXG4gIHJlYWRvbmx5IGxhdGVuY3lPdXRsaWVyVGhyZXNob2xkPzogbnVtYmVyO1xuICBcbn0iXX0=
|
|
@@ -1,26 +1,40 @@
|
|
|
1
1
|
import { Duration } from 'aws-cdk-lib';
|
|
2
|
-
import { IAlarm
|
|
2
|
+
import { IAlarm } from 'aws-cdk-lib/aws-cloudwatch';
|
|
3
3
|
import { AvailabilityZoneMapper } from '../../azmapper/AvailabilityZoneMapper';
|
|
4
|
+
import { ApplicationLoadBalancerDetectionProps } from './ApplicationLoadBalancerDetectionProps';
|
|
5
|
+
import { NatGatewayDetectionProps } from './NatGatewayDetectionProps';
|
|
4
6
|
/**
|
|
5
7
|
* The properties for creating a dashboard with basic metrics
|
|
6
8
|
*/
|
|
7
9
|
export interface BasicServiceDashboardProps {
|
|
10
|
+
/**
|
|
11
|
+
* The service's name
|
|
12
|
+
*/
|
|
8
13
|
readonly serviceName: string;
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
readonly zonalNatGatewayIsolatedImpactAlarms?: {
|
|
13
|
-
[key: string]: IAlarm;
|
|
14
|
-
};
|
|
14
|
+
/**
|
|
15
|
+
* The alarms indicating a single AZ impact, one per AZ
|
|
16
|
+
*/
|
|
15
17
|
readonly zonalAggregateIsolatedImpactAlarms: {
|
|
16
18
|
[key: string]: IAlarm;
|
|
17
19
|
};
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
readonly zonalNatGatewayPacketDropMetrics?: {
|
|
22
|
-
[key: string]: IMetric;
|
|
23
|
-
};
|
|
20
|
+
/**
|
|
21
|
+
* The interval for the dashboard
|
|
22
|
+
*/
|
|
24
23
|
readonly interval?: Duration;
|
|
24
|
+
/**
|
|
25
|
+
* The AZ mapper to convert AZ name/letter to AZ ID
|
|
26
|
+
*/
|
|
25
27
|
readonly azMapper: AvailabilityZoneMapper;
|
|
28
|
+
/**
|
|
29
|
+
* The ALBs being used for the service
|
|
30
|
+
*/
|
|
31
|
+
readonly albs?: ApplicationLoadBalancerDetectionProps;
|
|
32
|
+
/**
|
|
33
|
+
* The NAT Gateways being used for the service, a list of gateways per Availability zone
|
|
34
|
+
*/
|
|
35
|
+
readonly natgws?: NatGatewayDetectionProps;
|
|
36
|
+
/**
|
|
37
|
+
* The period for metric measurement
|
|
38
|
+
*/
|
|
39
|
+
readonly period: Duration;
|
|
26
40
|
}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQmFzaWNTZXJ2aWNlRGFzaGJvYXJkUHJvcHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYmFzaWNfb2JzZXJ2YWJpbGl0eS9wcm9wcy9CYXNpY1NlcnZpY2VEYXNoYm9hcmRQcm9wcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IEFtYXpvbi5jb20sIEluYy4gb3IgaXRzIGFmZmlsaWF0ZXMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4vLyBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuaW1wb3J0IHsgRHVyYXRpb24gfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBJQWxhcm0gfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY2xvdWR3YXRjaCc7XG5pbXBvcnQgeyBBdmFpbGFiaWxpdHlab25lTWFwcGVyIH0gZnJvbSAnLi4vLi4vYXptYXBwZXIvQXZhaWxhYmlsaXR5Wm9uZU1hcHBlcic7XG5pbXBvcnQgeyBBcHBsaWNhdGlvbkxvYWRCYWxhbmNlckRldGVjdGlvblByb3BzIH0gZnJvbSAnLi9BcHBsaWNhdGlvbkxvYWRCYWxhbmNlckRldGVjdGlvblByb3BzJztcbmltcG9ydCB7IE5hdEdhdGV3YXlEZXRlY3Rpb25Qcm9wcyB9IGZyb20gJy4vTmF0R2F0ZXdheURldGVjdGlvblByb3BzJztcblxuLyoqXG4gKiBUaGUgcHJvcGVydGllcyBmb3IgY3JlYXRpbmcgYSBkYXNoYm9hcmQgd2l0aCBiYXNpYyBtZXRyaWNzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQmFzaWNTZXJ2aWNlRGFzaGJvYXJkUHJvcHMge1xuXG4gIC8qKlxuICAgKiBUaGUgc2VydmljZSdzIG5hbWVcbiAgICovXG4gIHJlYWRvbmx5IHNlcnZpY2VOYW1lOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBhbGFybXMgaW5kaWNhdGluZyBhIHNpbmdsZSBBWiBpbXBhY3QsIG9uZSBwZXIgQVpcbiAgICovXG4gIHJlYWRvbmx5IHpvbmFsQWdncmVnYXRlSXNvbGF0ZWRJbXBhY3RBbGFybXM6IHsgW2tleTogc3RyaW5nXTogSUFsYXJtIH07XG5cbiAgLyoqXG4gICAqIFRoZSBpbnRlcnZhbCBmb3IgdGhlIGRhc2hib2FyZFxuICAgKi9cbiAgcmVhZG9ubHkgaW50ZXJ2YWw/OiBEdXJhdGlvbjtcblxuICAvKipcbiAgICogVGhlIEFaIG1hcHBlciB0byBjb252ZXJ0IEFaIG5hbWUvbGV0dGVyIHRvIEFaIElEXG4gICAqL1xuICByZWFkb25seSBhek1hcHBlcjogQXZhaWxhYmlsaXR5Wm9uZU1hcHBlcjtcblxuICAvKipcbiAgICogVGhlIEFMQnMgYmVpbmcgdXNlZCBmb3IgdGhlIHNlcnZpY2VcbiAgICovXG4gIHJlYWRvbmx5IGFsYnM/OiBBcHBsaWNhdGlvbkxvYWRCYWxhbmNlckRldGVjdGlvblByb3BzO1xuXG4gIC8qKlxuICAgKiBUaGUgTkFUIEdhdGV3YXlzIGJlaW5nIHVzZWQgZm9yIHRoZSBzZXJ2aWNlLCBhIGxpc3Qgb2YgZ2F0ZXdheXMgcGVyIEF2YWlsYWJpbGl0eSB6b25lXG4gICAqL1xuICByZWFkb25seSBuYXRnd3M/OiBOYXRHYXRld2F5RGV0ZWN0aW9uUHJvcHM7XG5cbiAgLyoqXG4gICAqIFRoZSBwZXJpb2QgZm9yIG1ldHJpYyBtZWFzdXJlbWVudFxuICAgKi9cbiAgcmVhZG9ubHkgcGVyaW9kOiBEdXJhdGlvbjtcbn1cbiJdfQ==
|
|
@@ -1,56 +1,28 @@
|
|
|
1
1
|
import { Duration } from 'aws-cdk-lib';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { ApplicationLoadBalancerDetectionProps } from './ApplicationLoadBalancerDetectionProps';
|
|
3
|
+
import { NatGatewayDetectionProps } from './NatGatewayDetectionProps';
|
|
4
4
|
/**
|
|
5
5
|
* Properties for creating basic multi-AZ observability
|
|
6
6
|
*/
|
|
7
7
|
export interface BasicServiceMultiAZObservabilityProps {
|
|
8
8
|
/**
|
|
9
|
-
*
|
|
10
|
-
*
|
|
11
|
-
* are provided for a single AZ, those alarms will be aggregated into
|
|
12
|
-
* a composite alarm for the AZ. You must either specify an ALB or a NAT GW.
|
|
9
|
+
* Properties for NAT Gateways to detect single AZ impact. You must specify
|
|
10
|
+
* this and/or applicationLoadBalancerProps.
|
|
13
11
|
*
|
|
14
|
-
* @default "No
|
|
12
|
+
* @default "No NAT Gateways will be used to calculate impact."
|
|
15
13
|
*/
|
|
16
|
-
readonly
|
|
17
|
-
[key: string]: CfnNatGateway[];
|
|
18
|
-
};
|
|
14
|
+
readonly natGatewayProps?: NatGatewayDetectionProps;
|
|
19
15
|
/**
|
|
20
|
-
*
|
|
21
|
-
*
|
|
22
|
-
* of all ALBs. You must either specify an ALB or a NAT GW.
|
|
16
|
+
* Properties for ALBs to detect single AZ impact. You must specify this
|
|
17
|
+
* and/or natGatewayProps.
|
|
23
18
|
*
|
|
24
|
-
* @default "No
|
|
19
|
+
* @default "No ALBs will be used to calculate impact."
|
|
25
20
|
*/
|
|
26
|
-
readonly
|
|
21
|
+
readonly applicationLoadBalancerProps?: ApplicationLoadBalancerDetectionProps;
|
|
27
22
|
/**
|
|
28
23
|
* The service's name
|
|
29
24
|
*/
|
|
30
25
|
readonly serviceName: string;
|
|
31
|
-
/**
|
|
32
|
-
* The amount of packet loss in a NAT GW to determine if an AZ
|
|
33
|
-
* is actually impacted, recommendation is 0.01%
|
|
34
|
-
*
|
|
35
|
-
* @default "0.01 (as in 0.01%)"
|
|
36
|
-
*/
|
|
37
|
-
readonly packetLossImpactPercentageThreshold?: number;
|
|
38
|
-
/**
|
|
39
|
-
* The percentage of faults for a single ALB to consider an AZ
|
|
40
|
-
* to be unhealthy, this should align with your availability goal. For example
|
|
41
|
-
* 1% or 5%, specify as 1 or 5.
|
|
42
|
-
*/
|
|
43
|
-
readonly faultCountPercentageThreshold: number;
|
|
44
|
-
/**
|
|
45
|
-
* The threshold in seconds for ALB targets whose responses are slower than this
|
|
46
|
-
* value at the specified percentile statistic.
|
|
47
|
-
*/
|
|
48
|
-
readonly latencyThreshold: number;
|
|
49
|
-
/**
|
|
50
|
-
* The statistic used to measure target response latency, like p99,
|
|
51
|
-
* which can be specified using Stats.percentile(99) or "p99".
|
|
52
|
-
*/
|
|
53
|
-
readonly latencyStatistic: string;
|
|
54
26
|
/**
|
|
55
27
|
* The period to evaluate metrics
|
|
56
28
|
*
|
|
@@ -2,4 +2,4 @@
|
|
|
2
2
|
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
3
3
|
// SPDX-License-Identifier: Apache-2.0
|
|
4
4
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQmFzaWNTZXJ2aWNlTXVsdGlBWk9ic2VydmFiaWxpdHlQcm9wcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iYXNpY19vYnNlcnZhYmlsaXR5L3Byb3BzL0Jhc2ljU2VydmljZU11bHRpQVpPYnNlcnZhYmlsaXR5UHJvcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHFFQUFxRTtBQUNyRSxzQ0FBc0MiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgQW1hem9uLmNvbSwgSW5jLiBvciBpdHMgYWZmaWxpYXRlcy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbi8vIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBBcGFjaGUtMi4wXG5cbmltcG9ydCB7IER1cmF0aW9uIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHsgQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJEZXRlY3Rpb25Qcm9wcyB9IGZyb20gJy4vQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJEZXRlY3Rpb25Qcm9wcyc7XG5pbXBvcnQgeyBOYXRHYXRld2F5RGV0ZWN0aW9uUHJvcHMgfSBmcm9tICcuL05hdEdhdGV3YXlEZXRlY3Rpb25Qcm9wcyc7XG5cbi8qKlxuICogUHJvcGVydGllcyBmb3IgY3JlYXRpbmcgYmFzaWMgbXVsdGktQVogb2JzZXJ2YWJpbGl0eVxuICovXG5leHBvcnQgaW50ZXJmYWNlIEJhc2ljU2VydmljZU11bHRpQVpPYnNlcnZhYmlsaXR5UHJvcHMge1xuICAvKipcbiAgICogUHJvcGVydGllcyBmb3IgTkFUIEdhdGV3YXlzIHRvIGRldGVjdCBzaW5nbGUgQVogaW1wYWN0LiBZb3UgbXVzdCBzcGVjaWZ5XG4gICAqIHRoaXMgYW5kL29yIGFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyUHJvcHMuXG4gICAqIFxuICAgKiBAZGVmYXVsdCBcIk5vIE5BVCBHYXRld2F5cyB3aWxsIGJlIHVzZWQgdG8gY2FsY3VsYXRlIGltcGFjdC5cIlxuICAgKi9cbiAgcmVhZG9ubHkgbmF0R2F0ZXdheVByb3BzPzogTmF0R2F0ZXdheURldGVjdGlvblByb3BzO1xuXG4gIC8qKlxuICAgKiBQcm9wZXJ0aWVzIGZvciBBTEJzIHRvIGRldGVjdCBzaW5nbGUgQVogaW1wYWN0LiBZb3UgbXVzdCBzcGVjaWZ5IHRoaXNcbiAgICogYW5kL29yIG5hdEdhdGV3YXlQcm9wcy5cbiAgICogXG4gICAqIEBkZWZhdWx0IFwiTm8gQUxCcyB3aWxsIGJlIHVzZWQgdG8gY2FsY3VsYXRlIGltcGFjdC5cIlxuICAgKi9cbiAgcmVhZG9ubHkgYXBwbGljYXRpb25Mb2FkQmFsYW5jZXJQcm9wcz86IEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyRGV0ZWN0aW9uUHJvcHM7XG5cbiAgLyoqXG4gICAqIFRoZSBzZXJ2aWNlJ3MgbmFtZVxuICAgKi9cbiAgcmVhZG9ubHkgc2VydmljZU5hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHBlcmlvZCB0byBldmFsdWF0ZSBtZXRyaWNzXG4gICAqIFxuICAgKiBAZGVmYXVsdCBEdXJhdGlvbi5taW51dGVzKDEpXG4gICAqL1xuICByZWFkb25seSBwZXJpb2Q/OiBEdXJhdGlvbjtcblxuICAvKipcbiAgICogV2hldGhlciB0byBjcmVhdGUgYSBkYXNoYm9hcmQgZGlzcGxheWluZyB0aGUgbWV0cmljcyBhbmQgYWxhcm1zXG4gICAqIFxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkgY3JlYXRlRGFzaGJvYXJkPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogRGFzaGJvYXJkIGludGVydmFsXG4gICAqXG4gICAqIEBkZWZhdWx0IER1cmF0aW9uLmhvdXJzKDEpXG4gICAqL1xuICByZWFkb25seSBpbnRlcnZhbD86IER1cmF0aW9uO1xuXG4gIC8qKlxuICAgKiBJZiB5b3UgYXJlIG5vdCB1c2luZyBhIHN0YXRpYyBidWNrZXQgdG8gZGVwbG95IGFzc2V0cywgZm9yIGV4YW1wbGVcbiAgICogeW91IGFyZSBzeW50aGluZyB0aGlzIGFuZCBpdCBnZXRzIHVwbG9hZGVkIHRvIGEgYnVja2V0IHdob3NlIG5hbWVcbiAgICogaXMgdW5rbm93biB0byB5b3UgKG1heWJlIHVzZWQgYXMgcGFydCBvZiBhIGNlbnRyYWwgQ0kvQ0Qgc3lzdGVtKVxuICAgKiBhbmQgaXMgcHJvdmlkZWQgYXMgYSBwYXJhbWV0ZXIgdG8geW91ciBzdGFjaywgc3BlY2lmeSB0aGF0IHBhcmFtZXRlclxuICAgKiBuYW1lIGhlcmUuIEl0IHdpbGwgb3ZlcnJpZGUgdGhlIGJ1Y2tldCBsb2NhdGlvbiBDREsgcHJvdmlkZXMgYnlcbiAgICogZGVmYXVsdCBmb3IgYnVuZGxlZCBhc3NldHMuIFRoZSBzdGFjayBjb250YWluaW5nIHRoaXMgY29udHJ1Y3QgbmVlZHNcbiAgICogdG8gaGF2ZSBhIHBhcmFtZXRlciBkZWZpbmVkIHRoYXQgdXNlcyB0aGlzIG5hbWUuIFRoZSB1bmRlcmx5aW5nXG4gICAqIHN0YWNrcyBpbiB0aGlzIGNvbnN0cnVjdCB0aGF0IGRlcGxveSBhc3NldHMgd2lsbCBjb3B5IHRoZSBwYXJlbnQgc3RhY2snc1xuICAgKiB2YWx1ZSBmb3IgdGhpcyBwcm9wZXJ0eS5cbiAgICpcbiAgICogQGRlZmF1bHQgXCJUaGUgYXNzZXRzIHdpbGwgYmUgdXBsb2FkZWQgdG8gdGhlIGRlZmF1bHQgZGVmaW5lZCBhc3NldCBsb2NhdGlvbi5cIlxuICAgKi9cbiAgcmVhZG9ubHkgYXNzZXRzQnVja2V0UGFyYW1ldGVyTmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogSWYgeW91IGFyZSBub3QgdXNpbmcgYSBzdGF0aWMgYnVja2V0IHRvIGRlcGxveSBhc3NldHMsIGZvciBleGFtcGxlXG4gICAqIHlvdSBhcmUgc3ludGhpbmcgdGhpcyBhbmQgaXQgZ2V0cyB1cGxvYWRlZCB0byBhIGJ1Y2tldCB0aGF0IHVzZXMgYSBwcmVmaXhcbiAgICogdGhhdCBpcyB1bmtub3duIHRvIHlvdSAobWF5YmUgdXNlZCBhcyBwYXJ0IG9mIGEgY2VudHJhbCBDSS9DRCBzeXN0ZW0pXG4gICAqIGFuZCBpcyBwcm92aWRlZCBhcyBhIHBhcmFtZXRlciB0byB5b3VyIHN0YWNrLCBzcGVjaWZ5IHRoYXQgcGFyYW1ldGVyXG4gICAqIG5hbWUgaGVyZS4gSXQgd2lsbCBvdmVycmlkZSB0aGUgYnVja2V0IHByZWZpeCBDREsgcHJvdmlkZXMgYnlcbiAgICogZGVmYXVsdCBmb3IgYnVuZGxlZCBhc3NldHMuIFRoaXMgcHJvcGVydHkgb25seSB0YWtlcyBlZmZlY3QgaWYgeW91XG4gICAqIGRlZmluZWQgdGhlIGFzc2V0c0J1Y2tldFBhcmFtZXRlck5hbWUuIFRoZSBzdGFjayBjb250YWluaW5nIHRoaXMgY29udHJ1Y3QgbmVlZHNcbiAgICogdG8gaGF2ZSBhIHBhcmFtZXRlciBkZWZpbmVkIHRoYXQgdXNlcyB0aGlzIG5hbWUuIFRoZSB1bmRlcmx5aW5nXG4gICAqIHN0YWNrcyBpbiB0aGlzIGNvbnN0cnVjdCB0aGF0IGRlcGxveSBhc3NldHMgd2lsbCBjb3B5IHRoZSBwYXJlbnQgc3RhY2snc1xuICAgKiB2YWx1ZSBmb3IgdGhpcyBwcm9wZXJ0eS5cbiAgICpcbiAgICogQGRlZmF1bHQgXCJObyBvYmplY3QgcHJlZml4IHdpbGwgYmUgYWRkZWQgdG8geW91ciBjdXN0b20gYXNzZXRzIGxvY2F0aW9uLiBIb3dldmVyLCBpZiB5b3UgaGF2ZSBvdmVycmlkZGVuIHNvbWV0aGluZyBsaWtlIHRoZSAnQnVja2V0UHJlZml4JyBwcm9wZXJ0eSBpbiB5b3VyIHN0YWNrIHN5bnRoZXNpemVyIHdpdGggYSB2YXJpYWJsZSBsaWtlICcke0Fzc2V0c0J1Y2tldFByZWZpeH0nLCB5b3Ugd2lsbCBuZWVkIHRvIGRlZmluZSB0aGlzIHByb3BlcnR5IHNvIGl0IGRvZXNuJ3QgY2F1c2UgYSByZWZlcmVuY2UgZXJyb3IgZXZlbiBpZiB0aGUgcHJlZml4IHZhbHVlIGlzIGJsYW5rLlwiXG4gICAqL1xuICByZWFkb25seSBhc3NldHNCdWNrZXRQcmVmaXhQYXJhbWV0ZXJOYW1lPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgbnVtYmVyIG9mIGV2YWx1YXRpb24gcGVyaW9kcyBmb3IgbGF0ZW5jeSBhbmQgYXZhaWxhYmlsdGl5IGFsYXJtc1xuICAgKi9cbiAgcmVhZG9ubHkgZXZhbHVhdGlvblBlcmlvZHM6IG51bWJlcjtcblxuICAvKipcbiAgICogVGhlIG51bWJlciBvZiBkYXRhcG9pbnRzIHRvIGFsYXJtIG9uIGZvciBsYXRlbmN5IGFuZCBhdmFpbGFiaWxpdHkgYWxhcm1zXG4gICAqL1xuICByZWFkb25seSBkYXRhcG9pbnRzVG9BbGFybTogbnVtYmVyO1xufVxuIl19
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { CfnNatGateway } from "aws-cdk-lib/aws-ec2";
|
|
2
|
+
import { PacketLossOutlierAlgorithm } from "../../outlier-detection/PacketLossOutlierAlgorithm";
|
|
3
|
+
/**
|
|
4
|
+
* The properties for performing zonal impact detection with NAT Gateway(s).
|
|
5
|
+
*/
|
|
6
|
+
export interface NatGatewayDetectionProps {
|
|
7
|
+
/**
|
|
8
|
+
* A list of NAT Gateways per Availability Zone (using the AZ name as the key)
|
|
9
|
+
*/
|
|
10
|
+
readonly natGateways: {
|
|
11
|
+
[key: string]: CfnNatGateway[];
|
|
12
|
+
};
|
|
13
|
+
/**
|
|
14
|
+
* The percentage of packet loss at which you consider there to be impact.
|
|
15
|
+
*
|
|
16
|
+
* @default 0.01 (as in 0.01%)
|
|
17
|
+
*/
|
|
18
|
+
readonly packetLossPercentThreshold?: number;
|
|
19
|
+
/**
|
|
20
|
+
* The algorithm to use to calculate an AZ as an outlier for packet loss.
|
|
21
|
+
*
|
|
22
|
+
* @default PacketLossOutlierAlgorithm.STATIC
|
|
23
|
+
*/
|
|
24
|
+
readonly packetLossOutlierAlgorithm?: PacketLossOutlierAlgorithm;
|
|
25
|
+
/**
|
|
26
|
+
* The threshold used with the outlier calculation.
|
|
27
|
+
*
|
|
28
|
+
* @default "This depends on the outlier algorithm. STATIC: 66. Z-SCORE: 3."
|
|
29
|
+
*/
|
|
30
|
+
readonly packetLossOutlierThreshold?: number;
|
|
31
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTmF0R2F0ZXdheURldGVjdGlvblByb3BzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2Jhc2ljX29ic2VydmFiaWxpdHkvcHJvcHMvTmF0R2F0ZXdheURldGVjdGlvblByb3BzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZm5OYXRHYXRld2F5IH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1lYzJcIjtcbmltcG9ydCB7IFBhY2tldExvc3NPdXRsaWVyQWxnb3JpdGhtIH0gZnJvbSBcIi4uLy4uL291dGxpZXItZGV0ZWN0aW9uL1BhY2tldExvc3NPdXRsaWVyQWxnb3JpdGhtXCI7XG5cbi8qKlxuICogVGhlIHByb3BlcnRpZXMgZm9yIHBlcmZvcm1pbmcgem9uYWwgaW1wYWN0IGRldGVjdGlvbiB3aXRoIE5BVCBHYXRld2F5KHMpLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIE5hdEdhdGV3YXlEZXRlY3Rpb25Qcm9wcyB7XG5cbiAgICAvKipcbiAgICAgKiBBIGxpc3Qgb2YgTkFUIEdhdGV3YXlzIHBlciBBdmFpbGFiaWxpdHkgWm9uZSAodXNpbmcgdGhlIEFaIG5hbWUgYXMgdGhlIGtleSlcbiAgICAgKi9cbiAgICByZWFkb25seSBuYXRHYXRld2F5czoge1trZXk6IHN0cmluZ106IENmbk5hdEdhdGV3YXlbXX07XG5cbiAgICAvKipcbiAgICAgKiBUaGUgcGVyY2VudGFnZSBvZiBwYWNrZXQgbG9zcyBhdCB3aGljaCB5b3UgY29uc2lkZXIgdGhlcmUgdG8gYmUgaW1wYWN0LlxuICAgICAqIFxuICAgICAqIEBkZWZhdWx0IDAuMDEgKGFzIGluIDAuMDElKVxuICAgICAqL1xuICAgIHJlYWRvbmx5IHBhY2tldExvc3NQZXJjZW50VGhyZXNob2xkPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogVGhlIGFsZ29yaXRobSB0byB1c2UgdG8gY2FsY3VsYXRlIGFuIEFaIGFzIGFuIG91dGxpZXIgZm9yIHBhY2tldCBsb3NzLlxuICAgICAqIFxuICAgICAqIEBkZWZhdWx0IFBhY2tldExvc3NPdXRsaWVyQWxnb3JpdGhtLlNUQVRJQ1xuICAgICAqL1xuICAgIHJlYWRvbmx5IHBhY2tldExvc3NPdXRsaWVyQWxnb3JpdGhtPzogUGFja2V0TG9zc091dGxpZXJBbGdvcml0aG07XG5cbiAgICAvKipcbiAgICAgKiBUaGUgdGhyZXNob2xkIHVzZWQgd2l0aCB0aGUgb3V0bGllciBjYWxjdWxhdGlvbi5cbiAgICAgKiBcbiAgICAgKiBAZGVmYXVsdCBcIlRoaXMgZGVwZW5kcyBvbiB0aGUgb3V0bGllciBhbGdvcml0aG0uIFNUQVRJQzogNjYuIFotU0NPUkU6IDMuXCJcbiAgICAgKi9cbiAgICByZWFkb25seSBwYWNrZXRMb3NzT3V0bGllclRocmVzaG9sZD86IG51bWJlcjtcbn0iXX0=
|
|
@@ -10,6 +10,7 @@ const aws_iam_1 = require("aws-cdk-lib/aws-iam");
|
|
|
10
10
|
const aws_lambda_1 = require("aws-cdk-lib/aws-lambda");
|
|
11
11
|
const aws_logs_1 = require("aws-cdk-lib/aws-logs");
|
|
12
12
|
const constructs_1 = require("constructs");
|
|
13
|
+
const MetricsHelper_1 = require("../utilities/MetricsHelper");
|
|
13
14
|
class CanaryFunction extends constructs_1.Construct {
|
|
14
15
|
constructor(scope, id, props) {
|
|
15
16
|
super(scope, id);
|
|
@@ -51,8 +52,8 @@ class CanaryFunction extends constructs_1.Construct {
|
|
|
51
52
|
/*
|
|
52
53
|
let code: AssetCode = Code.fromAsset(path.join(__dirname, "src/"), {
|
|
53
54
|
bundling: {
|
|
54
|
-
//image: new Runtime('python3.
|
|
55
|
-
image:
|
|
55
|
+
//image: new Runtime('python3.13:latest-arm64', RuntimeFamily.PYTHON).bundlingImage,
|
|
56
|
+
image: MetricsHelper.PythonRuntime.bundlingImage,
|
|
56
57
|
command: [
|
|
57
58
|
'bash', '-c',
|
|
58
59
|
'pip install --no-cache -r requirements.txt -t /asset-output && cp --archive --update . /asset-output',
|
|
@@ -64,7 +65,7 @@ class CanaryFunction extends constructs_1.Construct {
|
|
|
64
65
|
let monitoringLayer = new aws_lambda_1.LayerVersion(this, 'MonitoringLayer', {
|
|
65
66
|
code: aws_lambda_1.Code.fromAsset(path.join(__dirname, '../monitoring/src/monitoring-layer.zip')),
|
|
66
67
|
compatibleArchitectures: [aws_lambda_1.Architecture.ARM_64],
|
|
67
|
-
compatibleRuntimes: [
|
|
68
|
+
compatibleRuntimes: [MetricsHelper_1.MetricsHelper.PythonRuntime],
|
|
68
69
|
});
|
|
69
70
|
if (props.vpc !== undefined && props.vpc != null) {
|
|
70
71
|
let sg = new aws_ec2_1.SecurityGroup(this, 'canarySecurityGroup', {
|
|
@@ -73,7 +74,7 @@ class CanaryFunction extends constructs_1.Construct {
|
|
|
73
74
|
allowAllOutbound: true,
|
|
74
75
|
});
|
|
75
76
|
this.function = new aws_lambda_1.Function(this, 'canary', {
|
|
76
|
-
runtime:
|
|
77
|
+
runtime: MetricsHelper_1.MetricsHelper.PythonRuntime,
|
|
77
78
|
code: aws_lambda_1.Code.fromAsset(path.join(__dirname, 'src/canary.zip')),
|
|
78
79
|
handler: 'index.handler',
|
|
79
80
|
role: executionRole,
|
|
@@ -99,7 +100,7 @@ class CanaryFunction extends constructs_1.Construct {
|
|
|
99
100
|
}
|
|
100
101
|
else {
|
|
101
102
|
this.function = new aws_lambda_1.Function(this, 'canary', {
|
|
102
|
-
runtime:
|
|
103
|
+
runtime: MetricsHelper_1.MetricsHelper.PythonRuntime,
|
|
103
104
|
code: aws_lambda_1.Code.fromAsset(path.join(__dirname, 'src/canary.zip')),
|
|
104
105
|
handler: 'index.handler',
|
|
105
106
|
role: executionRole,
|
|
@@ -149,4 +150,4 @@ class CanaryFunction extends constructs_1.Construct {
|
|
|
149
150
|
}
|
|
150
151
|
}
|
|
151
152
|
exports.CanaryFunction = CanaryFunction;
|
|
152
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CanaryFunction.js","sourceRoot":"","sources":["../../src/canaries/CanaryFunction.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 * as path from 'path';\nimport { Duration, Fn, RemovalPolicy } from 'aws-cdk-lib';\nimport { ISecurityGroup, SecurityGroup } from 'aws-cdk-lib/aws-ec2';\nimport {\n  Effect,\n  IManagedPolicy,\n  IRole,\n  ManagedPolicy,\n  PolicyStatement,\n  Role,\n  ServicePrincipal,\n} from 'aws-cdk-lib/aws-iam';\nimport {\n  Architecture,\n  Code,\n  Function,\n  IFunction,\n  ILayerVersion,\n  LayerVersion,\n  Runtime,\n  Tracing,\n} from 'aws-cdk-lib/aws-lambda';\nimport { ILogGroup, LogGroup, RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { Construct } from 'constructs';\nimport { ICanaryFunction } from './ICanaryFunction';\nimport { CanaryFunctionProps } from './props/CanaryFunctionProps';\n\nexport class CanaryFunction extends Construct implements ICanaryFunction {\n  /**\n   * The canary function\n   */\n  function: IFunction;\n\n  /**\n   * The log group where the canarty logs will be sent\n   */\n  logGroup: ILogGroup;\n\n  constructor(scope: Construct, id: string, props: CanaryFunctionProps) {\n    super(scope, id);\n\n    let xrayManagedPolicy: IManagedPolicy = new ManagedPolicy(\n      this,\n      'xrayManagedPolicy',\n      {\n        path: '/canary/',\n        statements: [\n          new PolicyStatement({\n            actions: [\n              'xray:PutTraceSegments',\n              'xray:PutTelemetryRecords',\n              'xray:GetSamplingRules',\n              'xray:GetSamplingTargets',\n              'xray:GetSamplingStatisticSummaries',\n            ],\n            effect: Effect.ALLOW,\n            resources: ['*'],\n          }),\n        ],\n      },\n    );\n    let ec2ManagedPolicy = new ManagedPolicy(this, 'ec2ManagedPolicy', {\n      path: '/canary/',\n      statements: [\n        new PolicyStatement({\n          actions: [\n            'ec2:CreateNetworkInterface',\n            'ec2:DescribeNetworkInterfaces',\n            'ec2:DeleteNetworkInterface',\n          ],\n          effect: Effect.ALLOW,\n          resources: ['*'],\n        }),\n      ],\n    });\n\n    let executionRole: IRole = new Role(this, 'executionRole', {\n      assumedBy: new ServicePrincipal('lambda.amazonaws.com'),\n      path: '/canary/',\n      managedPolicies: [xrayManagedPolicy, ec2ManagedPolicy],\n    });\n\n    /*\n    let code: AssetCode = Code.fromAsset(path.join(__dirname, \"src/\"), {\n      bundling: {\n        //image: new Runtime('python3.12:latest-arm64', RuntimeFamily.PYTHON).bundlingImage,\n        image: Runtime.PYTHON_3_12.bundlingImage,\n        command: [\n          'bash', '-c',\n          'pip install --no-cache -r requirements.txt -t /asset-output && cp --archive --update . /asset-output',\n        ],\n        platform: 'linux/arm64',\n      },\n    });\n    */\n    let monitoringLayer: ILayerVersion = new LayerVersion(\n      this,\n      'MonitoringLayer',\n      {\n        code: Code.fromAsset(\n          path.join(__dirname, '../monitoring/src/monitoring-layer.zip'),\n        ),\n        compatibleArchitectures: [Architecture.ARM_64],\n        compatibleRuntimes: [Runtime.PYTHON_3_12],\n      },\n    );\n\n    if (props.vpc !== undefined && props.vpc != null) {\n      let sg: ISecurityGroup = new SecurityGroup(this, 'canarySecurityGroup', {\n        description: 'Allow canary to communicate with load balancer',\n        vpc: props.vpc,\n        allowAllOutbound: true,\n      });\n\n      this.function = new Function(this, 'canary', {\n        runtime: Runtime.PYTHON_3_12,\n        code: Code.fromAsset(path.join(__dirname, 'src/canary.zip')),\n        handler: 'index.handler',\n        role: executionRole,\n        architecture: Architecture.ARM_64,\n        tracing: Tracing.ACTIVE,\n        timeout: Duration.seconds(240),\n        memorySize: 512,\n        layers: [monitoringLayer],\n        environment: {\n          REGION: Fn.ref('AWS::Region'),\n          PARTITION: Fn.ref('AWS::Partition'),\n          TIMEOUT:\n            props.httpTimeout !== undefined\n              ? props.httpTimeout.toSeconds().toString()\n              : '2',\n          IGNORE_SSL_ERRORS: (\n            props.ignoreTlsErrors !== undefined && props.ignoreTlsErrors == true\n          )\n            .toString()\n            .toLowerCase(),\n        },\n        vpc: props.vpc,\n        securityGroups: [sg],\n        vpcSubnets: props.subnetSelection,\n      });\n    } else {\n      this.function = new Function(this, 'canary', {\n        runtime: Runtime.PYTHON_3_12,\n        code: Code.fromAsset(path.join(__dirname, 'src/canary.zip')),\n        handler: 'index.handler',\n        role: executionRole,\n        architecture: Architecture.ARM_64,\n        tracing: Tracing.ACTIVE,\n        timeout: Duration.seconds(240),\n        memorySize: 512,\n        layers: [monitoringLayer],\n        environment: {\n          REGION: Fn.ref('AWS::Region'),\n          PARTITION: Fn.ref('AWS::Partition'),\n          TIMEOUT:\n            props.httpTimeout !== undefined\n              ? props.httpTimeout.toSeconds().toString()\n              : '2',\n          IGNORE_SSL_ERRORS: (\n            props.ignoreTlsErrors !== undefined && props.ignoreTlsErrors == true\n          )\n            .toString()\n            .toLowerCase(),\n        },\n      });\n    }\n\n    this.function.addPermission('invokePermission', {\n      action: 'lambda:InvokeFunction',\n      principal: new ServicePrincipal('events.amazonaws.com'),\n      sourceArn: Fn.sub(\n        'arn:${AWS::Partition}:events:${AWS::Region}:${AWS::AccountId}:rule/*',\n      ),\n    });\n\n    this.logGroup = new LogGroup(this, 'logGroup', {\n      logGroupName: `/aws/lambda/${this.function.functionName}`,\n      retention: RetentionDays.ONE_WEEK,\n      removalPolicy: RemovalPolicy.DESTROY,\n    });\n\n    new ManagedPolicy(this, 'cwManagedPolicy', {\n      path: '/canary/',\n      statements: [\n        new PolicyStatement({\n          actions: ['cloudwatch:PutMetricData'],\n          effect: Effect.ALLOW,\n          resources: ['*'],\n        }),\n        new PolicyStatement({\n          actions: ['logs:CreateLogStream', 'logs:PutLogEvents'],\n          effect: Effect.ALLOW,\n          resources: [this.logGroup.logGroupArn],\n        }),\n      ],\n      roles: [executionRole],\n    });\n  }\n}\n"]}
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CanaryFunction.js","sourceRoot":"","sources":["../../src/canaries/CanaryFunction.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 * as path from 'path';\nimport { Duration, Fn, RemovalPolicy } from 'aws-cdk-lib';\nimport { ISecurityGroup, SecurityGroup } from 'aws-cdk-lib/aws-ec2';\nimport {\n  Effect,\n  IManagedPolicy,\n  IRole,\n  ManagedPolicy,\n  PolicyStatement,\n  Role,\n  ServicePrincipal,\n} from 'aws-cdk-lib/aws-iam';\nimport {\n  Architecture,\n  Code,\n  Function,\n  IFunction,\n  ILayerVersion,\n  LayerVersion,\n  Tracing,\n} from 'aws-cdk-lib/aws-lambda';\nimport { ILogGroup, LogGroup, RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { Construct } from 'constructs';\nimport { ICanaryFunction } from './ICanaryFunction';\nimport { CanaryFunctionProps } from './props/CanaryFunctionProps';\nimport { MetricsHelper } from '../utilities/MetricsHelper';\n\nexport class CanaryFunction extends Construct implements ICanaryFunction {\n  /**\n   * The canary function\n   */\n  function: IFunction;\n\n  /**\n   * The log group where the canarty logs will be sent\n   */\n  logGroup: ILogGroup;\n\n  constructor(scope: Construct, id: string, props: CanaryFunctionProps) {\n    super(scope, id);\n\n    let xrayManagedPolicy: IManagedPolicy = new ManagedPolicy(\n      this,\n      'xrayManagedPolicy',\n      {\n        path: '/canary/',\n        statements: [\n          new PolicyStatement({\n            actions: [\n              'xray:PutTraceSegments',\n              'xray:PutTelemetryRecords',\n              'xray:GetSamplingRules',\n              'xray:GetSamplingTargets',\n              'xray:GetSamplingStatisticSummaries',\n            ],\n            effect: Effect.ALLOW,\n            resources: ['*'],\n          }),\n        ],\n      },\n    );\n    let ec2ManagedPolicy = new ManagedPolicy(this, 'ec2ManagedPolicy', {\n      path: '/canary/',\n      statements: [\n        new PolicyStatement({\n          actions: [\n            'ec2:CreateNetworkInterface',\n            'ec2:DescribeNetworkInterfaces',\n            'ec2:DeleteNetworkInterface',\n          ],\n          effect: Effect.ALLOW,\n          resources: ['*'],\n        }),\n      ],\n    });\n\n    let executionRole: IRole = new Role(this, 'executionRole', {\n      assumedBy: new ServicePrincipal('lambda.amazonaws.com'),\n      path: '/canary/',\n      managedPolicies: [xrayManagedPolicy, ec2ManagedPolicy],\n    });\n\n    /*\n    let code: AssetCode = Code.fromAsset(path.join(__dirname, \"src/\"), {\n      bundling: {\n        //image: new Runtime('python3.13:latest-arm64', RuntimeFamily.PYTHON).bundlingImage,\n        image: MetricsHelper.PythonRuntime.bundlingImage,\n        command: [\n          'bash', '-c',\n          'pip install --no-cache -r requirements.txt -t /asset-output && cp --archive --update . /asset-output',\n        ],\n        platform: 'linux/arm64',\n      },\n    });\n    */\n    let monitoringLayer: ILayerVersion = new LayerVersion(\n      this,\n      'MonitoringLayer',\n      {\n        code: Code.fromAsset(\n          path.join(__dirname, '../monitoring/src/monitoring-layer.zip'),\n        ),\n        compatibleArchitectures: [Architecture.ARM_64],\n        compatibleRuntimes: [MetricsHelper.PythonRuntime],\n      },\n    );\n\n    if (props.vpc !== undefined && props.vpc != null) {\n      let sg: ISecurityGroup = new SecurityGroup(this, 'canarySecurityGroup', {\n        description: 'Allow canary to communicate with load balancer',\n        vpc: props.vpc,\n        allowAllOutbound: true,\n      });\n\n      this.function = new Function(this, 'canary', {\n        runtime: MetricsHelper.PythonRuntime,\n        code: Code.fromAsset(path.join(__dirname, 'src/canary.zip')),\n        handler: 'index.handler',\n        role: executionRole,\n        architecture: Architecture.ARM_64,\n        tracing: Tracing.ACTIVE,\n        timeout: Duration.seconds(240),\n        memorySize: 512,\n        layers: [monitoringLayer],\n        environment: {\n          REGION: Fn.ref('AWS::Region'),\n          PARTITION: Fn.ref('AWS::Partition'),\n          TIMEOUT:\n            props.httpTimeout !== undefined\n              ? props.httpTimeout.toSeconds().toString()\n              : '2',\n          IGNORE_SSL_ERRORS: (\n            props.ignoreTlsErrors !== undefined && props.ignoreTlsErrors == true\n          )\n            .toString()\n            .toLowerCase(),\n        },\n        vpc: props.vpc,\n        securityGroups: [sg],\n        vpcSubnets: props.subnetSelection,\n      });\n    } else {\n      this.function = new Function(this, 'canary', {\n        runtime: MetricsHelper.PythonRuntime,\n        code: Code.fromAsset(path.join(__dirname, 'src/canary.zip')),\n        handler: 'index.handler',\n        role: executionRole,\n        architecture: Architecture.ARM_64,\n        tracing: Tracing.ACTIVE,\n        timeout: Duration.seconds(240),\n        memorySize: 512,\n        layers: [monitoringLayer],\n        environment: {\n          REGION: Fn.ref('AWS::Region'),\n          PARTITION: Fn.ref('AWS::Partition'),\n          TIMEOUT:\n            props.httpTimeout !== undefined\n              ? props.httpTimeout.toSeconds().toString()\n              : '2',\n          IGNORE_SSL_ERRORS: (\n            props.ignoreTlsErrors !== undefined && props.ignoreTlsErrors == true\n          )\n            .toString()\n            .toLowerCase(),\n        },\n      });\n    }\n\n    this.function.addPermission('invokePermission', {\n      action: 'lambda:InvokeFunction',\n      principal: new ServicePrincipal('events.amazonaws.com'),\n      sourceArn: Fn.sub(\n        'arn:${AWS::Partition}:events:${AWS::Region}:${AWS::AccountId}:rule/*',\n      ),\n    });\n\n    this.logGroup = new LogGroup(this, 'logGroup', {\n      logGroupName: `/aws/lambda/${this.function.functionName}`,\n      retention: RetentionDays.ONE_WEEK,\n      removalPolicy: RemovalPolicy.DESTROY,\n    });\n\n    new ManagedPolicy(this, 'cwManagedPolicy', {\n      path: '/canary/',\n      statements: [\n        new PolicyStatement({\n          actions: ['cloudwatch:PutMetricData'],\n          effect: Effect.ALLOW,\n          resources: ['*'],\n        }),\n        new PolicyStatement({\n          actions: ['logs:CreateLogStream', 'logs:PutLogEvents'],\n          effect: Effect.ALLOW,\n          resources: [this.logGroup.logGroupArn],\n        }),\n      ],\n      roles: [executionRole],\n    });\n  }\n}\n"]}
|
|
Binary file
|
|
@@ -6,15 +6,12 @@ import { OperationAvailabilityAndLatencyDashboardProps } from './props/Operation
|
|
|
6
6
|
* Creates an operation level availability and latency dashboard
|
|
7
7
|
*/
|
|
8
8
|
export declare class OperationAvailabilityAndLatencyDashboard extends Construct implements IOperationAvailabilityAndLatencyDashboard {
|
|
9
|
-
private static
|
|
10
|
-
private static
|
|
11
|
-
private static
|
|
12
|
-
private static createApplicationLoadBalancerWidgets;
|
|
13
|
-
private static createNetworkLoadBalancerWidgets;
|
|
9
|
+
private static readonly regionColor;
|
|
10
|
+
private static createServerSideWidgets;
|
|
11
|
+
private static createCanaryWidgets;
|
|
14
12
|
/**
|
|
15
13
|
* The operation level dashboard
|
|
16
14
|
*/
|
|
17
15
|
dashboard: Dashboard;
|
|
18
|
-
private azMapper;
|
|
19
16
|
constructor(scope: Construct, id: string, props: OperationAvailabilityAndLatencyDashboardProps);
|
|
20
17
|
}
|