cdk-monitoring-constructs
Version:
[](https://badge.fury.io/js/cdk-monitoring-constructs) [](https://m
97 lines • 14.9 kB
JavaScript
"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.OpenSearchIngestionPipelineMonitoring = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const aws_cloudwatch_1 = require("aws-cdk-lib/aws-cloudwatch");
const OpenSearchIngestionPipelineMetricFactory_1 = require("./OpenSearchIngestionPipelineMetricFactory");
const common_1 = require("../../common");
const dashboard_1 = require("../../dashboard");
/**
* @experimental This is subject to change if an L2 construct becomes available.
*/
class OpenSearchIngestionPipelineMonitoring extends common_1.Monitoring {
constructor(scope, props) {
super(scope, props);
const namingStrategy = new dashboard_1.MonitoringNamingStrategy({
...props,
fallbackConstructName: props.pipelineName,
});
this.title = namingStrategy.resolveHumanReadableName();
this.pipelineUrl = scope
.createAwsConsoleUrlFactory()
.getOsisPipelineUrl(props.pipelineName);
this.alarmFactory = this.createAlarmFactory(namingStrategy.resolveAlarmFriendlyName());
this.usageAlarmFactory = new common_1.UsageAlarmFactory(this.alarmFactory);
this.usageAnnotations = [];
const metricFactory = new OpenSearchIngestionPipelineMetricFactory_1.OpenSearchIngestionPipelineMetricFactory(scope.createMetricFactory(), props);
this.metricSinkRecordsInCount = metricFactory.metricSinkRecordsInCount();
this.metricSourceBytesReceivedSum =
metricFactory.metricSourceBytesReceivedSum();
this.metricSinkBulkRequestLatencyMax =
metricFactory.metricSinkBulkRequestLatencyMax();
this.metricSinkBulkPipelineLatencyMax =
metricFactory.metricSinkBulkPipelineLatencyMax();
this.metricDlqS3RecordsCount = metricFactory.metricDlqS3RecordsCount();
for (const disambiguator in props.addMaxDlqS3CountAlarm) {
const alarmProps = props.addMaxDlqS3CountAlarm[disambiguator];
const createdAlarm = this.usageAlarmFactory.addMaxCountAlarm(this.metricDlqS3RecordsCount, alarmProps, disambiguator);
this.usageAnnotations.push(createdAlarm.annotation);
this.addAlarm(createdAlarm);
}
props.useCreatedAlarms?.consume(this.createdAlarms());
}
summaryWidgets() {
return this.widgets();
}
widgets() {
return [
this.createTitleWidget(),
new aws_cloudwatch_1.Row(this.createLatencyWidget(common_1.ThirdWidth, common_1.DefaultGraphWidgetHeight), this.createIncomingDataWidget(common_1.ThirdWidth, common_1.DefaultGraphWidgetHeight), this.createDlqS3Widget(common_1.ThirdWidth, common_1.DefaultGraphWidgetHeight)),
];
}
createTitleWidget() {
return new dashboard_1.MonitoringHeaderWidget({
family: "OpenSearch Ingestion",
title: this.title,
goToLinkUrl: this.pipelineUrl,
});
}
createLatencyWidget(width, height) {
return new aws_cloudwatch_1.GraphWidget({
width,
height,
title: "Latency",
left: [
this.metricSinkBulkRequestLatencyMax,
this.metricSinkBulkPipelineLatencyMax,
],
leftYAxis: common_1.TimeAxisMillisFromZero,
});
}
createIncomingDataWidget(width, height) {
return new aws_cloudwatch_1.GraphWidget({
width,
height,
title: "Incoming data",
left: [this.metricSinkRecordsInCount],
leftYAxis: common_1.CountAxisFromZero,
right: [this.metricSourceBytesReceivedSum],
rightYAxis: common_1.CountAxisFromZero,
});
}
createDlqS3Widget(width, height) {
return new aws_cloudwatch_1.GraphWidget({
width,
height,
title: "DLQ",
left: [this.metricDlqS3RecordsCount],
leftYAxis: common_1.CountAxisFromZero,
leftAnnotations: this.usageAnnotations,
});
}
}
exports.OpenSearchIngestionPipelineMonitoring = OpenSearchIngestionPipelineMonitoring;
_a = JSII_RTTI_SYMBOL_1;
OpenSearchIngestionPipelineMonitoring[_a] = { fqn: "cdk-monitoring-constructs.OpenSearchIngestionPipelineMonitoring", version: "9.15.2" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"OpenSearchIngestionPipelineMonitoring.js","sourceRoot":"","sources":["OpenSearchIngestionPipelineMonitoring.ts"],"names":[],"mappings":"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","sourcesContent":["import type { HorizontalAnnotation, IWidget } from \"aws-cdk-lib/aws-cloudwatch\";\nimport { GraphWidget, Row } from \"aws-cdk-lib/aws-cloudwatch\";\n\nimport type { OpenSearchIngestionPipelineMetricFactoryProps } from \"./OpenSearchIngestionPipelineMetricFactory\";\nimport { OpenSearchIngestionPipelineMetricFactory } from \"./OpenSearchIngestionPipelineMetricFactory\";\nimport {\n  BaseMonitoringProps,\n  MaxUsageCountThreshold,\n  MetricWithAlarmSupport,\n  Monitoring,\n  AlarmFactory,\n  UsageAlarmFactory,\n  MonitoringScope,\n  ThirdWidth,\n  DefaultGraphWidgetHeight,\n  TimeAxisMillisFromZero,\n  CountAxisFromZero,\n} from \"../../common\";\nimport {\n  MonitoringNamingStrategy,\n  MonitoringHeaderWidget,\n} from \"../../dashboard\";\n\nexport interface OpenSearchIngestionPipelineMonitoringOptions\n  extends BaseMonitoringProps {\n  readonly addMaxDlqS3CountAlarm?: Record<string, MaxUsageCountThreshold>;\n}\n\nexport interface OpenSearchIngestionPipelineMonitoringProps\n  extends OpenSearchIngestionPipelineMetricFactoryProps,\n    OpenSearchIngestionPipelineMonitoringOptions {}\n\n/**\n * @experimental This is subject to change if an L2 construct becomes available.\n */\nexport class OpenSearchIngestionPipelineMonitoring extends Monitoring {\n  readonly title: string;\n  readonly pipelineUrl?: string;\n\n  readonly metricSinkRecordsInCount: MetricWithAlarmSupport;\n  readonly metricSourceBytesReceivedSum: MetricWithAlarmSupport;\n  readonly metricSinkBulkRequestLatencyMax: MetricWithAlarmSupport;\n  readonly metricSinkBulkPipelineLatencyMax: MetricWithAlarmSupport;\n  readonly metricDlqS3RecordsCount: MetricWithAlarmSupport;\n\n  readonly alarmFactory: AlarmFactory;\n  readonly usageAlarmFactory: UsageAlarmFactory;\n\n  readonly usageAnnotations: HorizontalAnnotation[];\n\n  constructor(\n    scope: MonitoringScope,\n    props: OpenSearchIngestionPipelineMonitoringProps,\n  ) {\n    super(scope, props);\n\n    const namingStrategy = new MonitoringNamingStrategy({\n      ...props,\n      fallbackConstructName: props.pipelineName,\n    });\n    this.title = namingStrategy.resolveHumanReadableName();\n    this.pipelineUrl = scope\n      .createAwsConsoleUrlFactory()\n      .getOsisPipelineUrl(props.pipelineName);\n\n    this.alarmFactory = this.createAlarmFactory(\n      namingStrategy.resolveAlarmFriendlyName(),\n    );\n    this.usageAlarmFactory = new UsageAlarmFactory(this.alarmFactory);\n\n    this.usageAnnotations = [];\n\n    const metricFactory = new OpenSearchIngestionPipelineMetricFactory(\n      scope.createMetricFactory(),\n      props,\n    );\n\n    this.metricSinkRecordsInCount = metricFactory.metricSinkRecordsInCount();\n    this.metricSourceBytesReceivedSum =\n      metricFactory.metricSourceBytesReceivedSum();\n    this.metricSinkBulkRequestLatencyMax =\n      metricFactory.metricSinkBulkRequestLatencyMax();\n    this.metricSinkBulkPipelineLatencyMax =\n      metricFactory.metricSinkBulkPipelineLatencyMax();\n    this.metricDlqS3RecordsCount = metricFactory.metricDlqS3RecordsCount();\n\n    for (const disambiguator in props.addMaxDlqS3CountAlarm) {\n      const alarmProps = props.addMaxDlqS3CountAlarm[disambiguator];\n      const createdAlarm = this.usageAlarmFactory.addMaxCountAlarm(\n        this.metricDlqS3RecordsCount,\n        alarmProps,\n        disambiguator,\n      );\n      this.usageAnnotations.push(createdAlarm.annotation);\n      this.addAlarm(createdAlarm);\n    }\n\n    props.useCreatedAlarms?.consume(this.createdAlarms());\n  }\n\n  summaryWidgets(): IWidget[] {\n    return this.widgets();\n  }\n\n  widgets(): IWidget[] {\n    return [\n      this.createTitleWidget(),\n      new Row(\n        this.createLatencyWidget(ThirdWidth, DefaultGraphWidgetHeight),\n        this.createIncomingDataWidget(ThirdWidth, DefaultGraphWidgetHeight),\n        this.createDlqS3Widget(ThirdWidth, DefaultGraphWidgetHeight),\n      ),\n    ];\n  }\n\n  protected createTitleWidget(): IWidget {\n    return new MonitoringHeaderWidget({\n      family: \"OpenSearch Ingestion\",\n      title: this.title,\n      goToLinkUrl: this.pipelineUrl,\n    });\n  }\n\n  protected createLatencyWidget(width: number, height: number): IWidget {\n    return new GraphWidget({\n      width,\n      height,\n      title: \"Latency\",\n      left: [\n        this.metricSinkBulkRequestLatencyMax,\n        this.metricSinkBulkPipelineLatencyMax,\n      ],\n      leftYAxis: TimeAxisMillisFromZero,\n    });\n  }\n\n  protected createIncomingDataWidget(width: number, height: number): IWidget {\n    return new GraphWidget({\n      width,\n      height,\n      title: \"Incoming data\",\n      left: [this.metricSinkRecordsInCount],\n      leftYAxis: CountAxisFromZero,\n      right: [this.metricSourceBytesReceivedSum],\n      rightYAxis: CountAxisFromZero,\n    });\n  }\n\n  protected createDlqS3Widget(width: number, height: number): IWidget {\n    return new GraphWidget({\n      width,\n      height,\n      title: \"DLQ\",\n      left: [this.metricDlqS3RecordsCount],\n      leftYAxis: CountAxisFromZero,\n      leftAnnotations: this.usageAnnotations,\n    });\n  }\n}\n"]}