cdk-monitoring-constructs
Version:
[](https://badge.fury.io/js/cdk-monitoring-constructs) [](https://m
63 lines • 11.6 kB
JavaScript
"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.RedshiftClusterMetricFactory = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const common_1 = require("../../common");
const RedshiftNamespace = "AWS/Redshift";
class RedshiftClusterMetricFactory extends common_1.BaseMetricFactory {
constructor(metricFactory, props) {
super(metricFactory, props);
this.dimensionsMap = {
ClusterIdentifier: props.clusterIdentifier,
};
}
metricTotalConnectionCount() {
return this.metric("DatabaseConnections", common_1.MetricStatistic.SUM, "Connections");
}
metricAverageDiskSpaceUsageInPercent() {
return this.metric("PercentageDiskSpaceUsed", common_1.MetricStatistic.AVERAGE, "Disk Usage");
}
metricAverageCpuUsageInPercent() {
return this.metric("CPUUtilization", common_1.MetricStatistic.AVERAGE, "CPU Usage");
}
metricShortQueryDurationP90InMillis() {
const sQueryLatency90 = this.metricQueryDuration("short", common_1.MetricStatistic.P90);
// need to convert micros to millis
return this.metricFactory.createMetricMath("sQueryLatency90 / 1000", { sQueryLatency90 }, "Short P90");
}
metricMediumQueryDurationP90InMillis() {
const mQueryLatency90 = this.metricQueryDuration("medium", common_1.MetricStatistic.P90);
// need to convert micros to millis
return this.metricFactory.createMetricMath("mQueryLatency90 / 1000", { mQueryLatency90 }, "Medium P90");
}
metricLongQueryDurationP90InMillis() {
const lQueryLatency90 = this.metricQueryDuration("long", common_1.MetricStatistic.P90);
// need to convert micros to millis
return this.metricFactory.createMetricMath("lQueryLatency90 / 1000", { lQueryLatency90 }, "Long P90");
}
metricMaintenanceModeEnabled() {
return this.metric("MaintenanceMode", common_1.MetricStatistic.MAX, "Maintenance");
}
metricReadLatencyP90InMillis() {
const readLatency = this.metric("ReadLatency", common_1.MetricStatistic.P90, "Read P90");
// need to convert seconds to millis
return this.metricFactory.createMetricMath("readLatency * 1000", { readLatency }, "Read P90");
}
metricWriteLatencyP90InMillis() {
const writeLatency = this.metric("WriteLatency", common_1.MetricStatistic.P90, "Write P90");
// need to convert seconds to millis
return this.metricFactory.createMetricMath("writeLatency * 1000", { writeLatency }, "Write P90");
}
metricQueryDuration(latency, statistic) {
const dimensions = { ...this.dimensionsMap, latency };
return this.metricFactory.createMetric("QueryDuration", statistic, latency, dimensions, undefined, RedshiftNamespace, undefined, this.region, this.account);
}
metric(metricName, statistic, label) {
return this.metricFactory.createMetric(metricName, statistic, label, this.dimensionsMap, undefined, RedshiftNamespace, undefined, this.region, this.account);
}
}
exports.RedshiftClusterMetricFactory = RedshiftClusterMetricFactory;
_a = JSII_RTTI_SYMBOL_1;
RedshiftClusterMetricFactory[_a] = { fqn: "cdk-monitoring-constructs.RedshiftClusterMetricFactory", version: "10.0.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RedshiftClusterMetricFactory.js","sourceRoot":"","sources":["RedshiftClusterMetricFactory.ts"],"names":[],"mappings":"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","sourcesContent":["import { DimensionsMap } from \"aws-cdk-lib/aws-cloudwatch\";\n\nimport {\n  BaseMetricFactory,\n  BaseMetricFactoryProps,\n  MetricFactory,\n  MetricStatistic,\n} from \"../../common\";\n\nconst RedshiftNamespace = \"AWS/Redshift\";\n\ntype QueryLatencyClass = \"short\" | \"medium\" | \"long\";\n\nexport interface RedshiftClusterMetricFactoryProps\n  extends BaseMetricFactoryProps {\n  readonly clusterIdentifier: string;\n}\n\nexport class RedshiftClusterMetricFactory extends BaseMetricFactory {\n  protected readonly dimensionsMap: DimensionsMap;\n\n  constructor(\n    metricFactory: MetricFactory,\n    props: RedshiftClusterMetricFactoryProps,\n  ) {\n    super(metricFactory, props);\n\n    this.dimensionsMap = {\n      ClusterIdentifier: props.clusterIdentifier,\n    };\n  }\n\n  metricTotalConnectionCount() {\n    return this.metric(\n      \"DatabaseConnections\",\n      MetricStatistic.SUM,\n      \"Connections\",\n    );\n  }\n\n  metricAverageDiskSpaceUsageInPercent() {\n    return this.metric(\n      \"PercentageDiskSpaceUsed\",\n      MetricStatistic.AVERAGE,\n      \"Disk Usage\",\n    );\n  }\n\n  metricAverageCpuUsageInPercent() {\n    return this.metric(\"CPUUtilization\", MetricStatistic.AVERAGE, \"CPU Usage\");\n  }\n\n  metricShortQueryDurationP90InMillis() {\n    const sQueryLatency90 = this.metricQueryDuration(\n      \"short\",\n      MetricStatistic.P90,\n    );\n    // need to convert micros to millis\n    return this.metricFactory.createMetricMath(\n      \"sQueryLatency90 / 1000\",\n      { sQueryLatency90 },\n      \"Short P90\",\n    );\n  }\n\n  metricMediumQueryDurationP90InMillis() {\n    const mQueryLatency90 = this.metricQueryDuration(\n      \"medium\",\n      MetricStatistic.P90,\n    );\n    // need to convert micros to millis\n    return this.metricFactory.createMetricMath(\n      \"mQueryLatency90 / 1000\",\n      { mQueryLatency90 },\n      \"Medium P90\",\n    );\n  }\n\n  metricLongQueryDurationP90InMillis() {\n    const lQueryLatency90 = this.metricQueryDuration(\n      \"long\",\n      MetricStatistic.P90,\n    );\n    // need to convert micros to millis\n    return this.metricFactory.createMetricMath(\n      \"lQueryLatency90 / 1000\",\n      { lQueryLatency90 },\n      \"Long P90\",\n    );\n  }\n\n  metricMaintenanceModeEnabled() {\n    return this.metric(\"MaintenanceMode\", MetricStatistic.MAX, \"Maintenance\");\n  }\n\n  metricReadLatencyP90InMillis() {\n    const readLatency = this.metric(\n      \"ReadLatency\",\n      MetricStatistic.P90,\n      \"Read P90\",\n    );\n    // need to convert seconds to millis\n    return this.metricFactory.createMetricMath(\n      \"readLatency * 1000\",\n      { readLatency },\n      \"Read P90\",\n    );\n  }\n\n  metricWriteLatencyP90InMillis() {\n    const writeLatency = this.metric(\n      \"WriteLatency\",\n      MetricStatistic.P90,\n      \"Write P90\",\n    );\n    // need to convert seconds to millis\n    return this.metricFactory.createMetricMath(\n      \"writeLatency * 1000\",\n      { writeLatency },\n      \"Write P90\",\n    );\n  }\n\n  private metricQueryDuration(\n    latency: QueryLatencyClass,\n    statistic: MetricStatistic,\n  ) {\n    const dimensions = { ...this.dimensionsMap, latency };\n    return this.metricFactory.createMetric(\n      \"QueryDuration\",\n      statistic,\n      latency,\n      dimensions,\n      undefined,\n      RedshiftNamespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  private metric(\n    metricName: string,\n    statistic: MetricStatistic,\n    label: string,\n  ) {\n    return this.metricFactory.createMetric(\n      metricName,\n      statistic,\n      label,\n      this.dimensionsMap,\n      undefined,\n      RedshiftNamespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n}\n"]}