cdk-monitoring-constructs
Version:
[](https://badge.fury.io/js/cdk-monitoring-constructs) [](https://m
105 lines • 15.6 kB
JavaScript
"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.NetworkLoadBalancerMetricFactory = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const aws_elasticloadbalancingv2_1 = require("aws-cdk-lib/aws-elasticloadbalancingv2");
const common_1 = require("../../common");
/**
* Metric factory to create metrics for network load-balanced service.
*/
class NetworkLoadBalancerMetricFactory extends common_1.BaseMetricFactory {
constructor(metricFactory, props) {
super(metricFactory, props);
this.networkLoadBalancer = props.networkLoadBalancer;
this.networkTargetGroup = props.networkTargetGroup;
this.invertStatisticsOfTaskCountEnabled =
props.invertStatisticsOfTaskCountEnabled ?? false;
}
metricHealthyTaskCount() {
return this.metricFactory.adaptMetric(this.networkTargetGroup.metrics.healthyHostCount({
label: "Healthy Tasks",
color: common_1.HealthyMetricColor,
statistic: this.invertStatisticsOfTaskCountEnabled
? common_1.MetricStatistic.MAX
: common_1.MetricStatistic.MIN,
region: this.region,
account: this.account,
}));
}
metricUnhealthyTaskCount() {
return this.metricFactory.adaptMetric(this.networkTargetGroup.metrics.unHealthyHostCount({
label: "Unhealthy Tasks",
color: common_1.UnhealthyMetricColor,
statistic: this.invertStatisticsOfTaskCountEnabled
? common_1.MetricStatistic.MIN
: common_1.MetricStatistic.MAX,
region: this.region,
account: this.account,
}));
}
metricHealthyTaskInPercent() {
return this.metricFactory.createMetricMath("(healthyTaskCount / (healthyTaskCount + unhealthyTaskCount)) * 100", {
healthyTaskCount: this.metricHealthyTaskCount(),
unhealthyTaskCount: this.metricUnhealthyTaskCount(),
}, "Healthy Task Percent (avg: ${AVG})");
}
metricActiveConnectionCount() {
return this.metricFactory.adaptMetric(this.networkLoadBalancer.metrics.activeFlowCount({
label: "Active",
region: this.region,
account: this.account,
}));
}
metricNewConnectionCount() {
return this.metricFactory.adaptMetric(this.networkLoadBalancer.metrics.newFlowCount({
label: "New",
region: this.region,
account: this.account,
}));
}
metricProcessedBytesMin() {
return this.metricFactory.adaptMetric(this.networkLoadBalancer.metrics.processedBytes({
statistic: common_1.MetricStatistic.MIN,
label: "Processed Bytes (min)",
region: this.region,
account: this.account,
}));
}
metricUnhealthyRoutingCount() {
const unhealthyRoutingFlowCount = this.metricFactory.adaptMetric(this.networkLoadBalancer.metrics.custom("UnhealthyRoutingFlowCount", {
statistic: common_1.MetricStatistic.SUM,
region: this.region,
account: this.account,
}));
return this.metricFactory.createMetricMath("FILL(unhealthyRoutingFlowCount, 0)", { unhealthyRoutingFlowCount }, "Unhealthy routing (fail open)");
}
metricClientResetCount() {
return this.metricFactory.adaptMetric(this.networkLoadBalancer.metrics.tcpClientResetCount({
label: "Client Reset",
statistic: common_1.MetricStatistic.SUM,
region: this.region,
account: this.account,
}));
}
metricTargetResetCount() {
return this.metricFactory.adaptMetric(this.networkLoadBalancer.metrics.tcpTargetResetCount({
label: "Target Reset",
statistic: common_1.MetricStatistic.SUM,
region: this.region,
account: this.account,
}));
}
metricElbResetCount() {
return this.metricFactory.adaptMetric(this.networkLoadBalancer.metrics.tcpElbResetCount({
label: "ELB Reset",
statistic: common_1.MetricStatistic.SUM,
region: this.region,
account: this.account,
}));
}
}
exports.NetworkLoadBalancerMetricFactory = NetworkLoadBalancerMetricFactory;
_a = JSII_RTTI_SYMBOL_1;
NetworkLoadBalancerMetricFactory[_a] = { fqn: "cdk-monitoring-constructs.NetworkLoadBalancerMetricFactory", version: "10.0.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"NetworkLoadBalancerMetricFactory.js","sourceRoot":"","sources":["NetworkLoadBalancerMetricFactory.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  INetworkLoadBalancer,\n  INetworkTargetGroup,\n  TargetType,\n} from \"aws-cdk-lib/aws-elasticloadbalancingv2\";\n\nimport {\n  BaseLoadBalancerMetricFactoryProps,\n  ILoadBalancerMetricFactory,\n} from \"./LoadBalancerMetricFactory\";\nimport {\n  BaseMetricFactory,\n  BaseMetricFactoryProps,\n  HealthyMetricColor,\n  MetricFactory,\n  MetricStatistic,\n  UnhealthyMetricColor,\n} from \"../../common\";\n\n/**\n * Props to create NetworkLoadBalancerMetricFactory.\n */\nexport interface NetworkLoadBalancerMetricFactoryProps\n  extends BaseLoadBalancerMetricFactoryProps,\n    BaseMetricFactoryProps {\n  readonly networkLoadBalancer: INetworkLoadBalancer;\n  readonly networkTargetGroup: INetworkTargetGroup;\n  /**\n   * Target type for the NetworkLoadBalancer.\n   * Set explicitly to ensure that unnecessary widgets are not rendered.\n   * By default, we will provide task health metrics, which are not\n   * relevant to the {@link TargetType.ALB} targets.\n   */\n  readonly networkLoadBalancerTargetType?: TargetType;\n}\n\n/**\n * Metric factory to create metrics for network load-balanced service.\n */\nexport class NetworkLoadBalancerMetricFactory\n  extends BaseMetricFactory\n  implements ILoadBalancerMetricFactory\n{\n  protected readonly networkLoadBalancer: INetworkLoadBalancer;\n  protected readonly networkTargetGroup: INetworkTargetGroup;\n  protected readonly invertStatisticsOfTaskCountEnabled: boolean;\n\n  constructor(\n    metricFactory: MetricFactory,\n    props: NetworkLoadBalancerMetricFactoryProps,\n  ) {\n    super(metricFactory, props);\n\n    this.networkLoadBalancer = props.networkLoadBalancer;\n    this.networkTargetGroup = props.networkTargetGroup;\n    this.invertStatisticsOfTaskCountEnabled =\n      props.invertStatisticsOfTaskCountEnabled ?? false;\n  }\n\n  metricHealthyTaskCount() {\n    return this.metricFactory.adaptMetric(\n      this.networkTargetGroup.metrics.healthyHostCount({\n        label: \"Healthy Tasks\",\n        color: HealthyMetricColor,\n        statistic: this.invertStatisticsOfTaskCountEnabled\n          ? MetricStatistic.MAX\n          : MetricStatistic.MIN,\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricUnhealthyTaskCount() {\n    return this.metricFactory.adaptMetric(\n      this.networkTargetGroup.metrics.unHealthyHostCount({\n        label: \"Unhealthy Tasks\",\n        color: UnhealthyMetricColor,\n        statistic: this.invertStatisticsOfTaskCountEnabled\n          ? MetricStatistic.MIN\n          : MetricStatistic.MAX,\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricHealthyTaskInPercent() {\n    return this.metricFactory.createMetricMath(\n      \"(healthyTaskCount / (healthyTaskCount + unhealthyTaskCount)) * 100\",\n      {\n        healthyTaskCount: this.metricHealthyTaskCount(),\n        unhealthyTaskCount: this.metricUnhealthyTaskCount(),\n      },\n      \"Healthy Task Percent (avg: ${AVG})\",\n    );\n  }\n\n  metricActiveConnectionCount() {\n    return this.metricFactory.adaptMetric(\n      this.networkLoadBalancer.metrics.activeFlowCount({\n        label: \"Active\",\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricNewConnectionCount() {\n    return this.metricFactory.adaptMetric(\n      this.networkLoadBalancer.metrics.newFlowCount({\n        label: \"New\",\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricProcessedBytesMin() {\n    return this.metricFactory.adaptMetric(\n      this.networkLoadBalancer.metrics.processedBytes({\n        statistic: MetricStatistic.MIN,\n        label: \"Processed Bytes (min)\",\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricUnhealthyRoutingCount() {\n    const unhealthyRoutingFlowCount = this.metricFactory.adaptMetric(\n      this.networkLoadBalancer.metrics.custom(\"UnhealthyRoutingFlowCount\", {\n        statistic: MetricStatistic.SUM,\n        region: this.region,\n        account: this.account,\n      }),\n    );\n\n    return this.metricFactory.createMetricMath(\n      \"FILL(unhealthyRoutingFlowCount, 0)\",\n      { unhealthyRoutingFlowCount },\n      \"Unhealthy routing (fail open)\",\n    );\n  }\n\n  metricClientResetCount() {\n    return this.metricFactory.adaptMetric(\n      this.networkLoadBalancer.metrics.tcpClientResetCount({\n        label: \"Client Reset\",\n        statistic: MetricStatistic.SUM,\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricTargetResetCount() {\n    return this.metricFactory.adaptMetric(\n      this.networkLoadBalancer.metrics.tcpTargetResetCount({\n        label: \"Target Reset\",\n        statistic: MetricStatistic.SUM,\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricElbResetCount() {\n    return this.metricFactory.adaptMetric(\n      this.networkLoadBalancer.metrics.tcpElbResetCount({\n        label: \"ELB Reset\",\n        statistic: MetricStatistic.SUM,\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n}\n"]}