cdk-monitoring-constructs
Version:
[](https://badge.fury.io/js/cdk-monitoring-constructs) [](https://m
250 lines • 33 kB
JavaScript
"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.LatencyAlarmFactory = exports.getLatencyTypeLabel = exports.getLatencyTypeExpressionId = exports.getLatencyTypeStatistic = exports.LatencyType = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const aws_cloudwatch_1 = require("aws-cdk-lib/aws-cloudwatch");
const metric_1 = require("../../metric");
var LatencyType;
(function (LatencyType) {
LatencyType["P50"] = "P50";
LatencyType["P70"] = "P70";
LatencyType["P90"] = "P90";
LatencyType["P95"] = "P95";
LatencyType["P99"] = "P99";
LatencyType["P999"] = "P999";
LatencyType["P9999"] = "P9999";
LatencyType["P100"] = "P100";
LatencyType["TM50"] = "TM50";
LatencyType["TM70"] = "TM70";
LatencyType["TM90"] = "TM90";
LatencyType["TM95"] = "TM95";
LatencyType["TM99"] = "TM99";
LatencyType["TM999"] = "TM999";
LatencyType["TM9999"] = "TM9999";
LatencyType["TM95_TOP"] = "TM(95%:100%)";
LatencyType["TM99_TOP"] = "TM(99%:100%)";
LatencyType["TM999_TOP"] = "TM(99.9%:100%)";
LatencyType["TM9999_TOP"] = "TM(99.99%:100%)";
LatencyType["AVERAGE"] = "Average";
LatencyType["MAX"] = "Maximum";
})(LatencyType = exports.LatencyType || (exports.LatencyType = {}));
function getLatencyTypeStatistic(latencyType) {
switch (latencyType) {
case LatencyType.P50:
return metric_1.MetricStatistic.P50;
case LatencyType.P70:
return metric_1.MetricStatistic.P70;
case LatencyType.P90:
return metric_1.MetricStatistic.P90;
case LatencyType.P95:
return metric_1.MetricStatistic.P95;
case LatencyType.P99:
return metric_1.MetricStatistic.P99;
case LatencyType.P999:
return metric_1.MetricStatistic.P999;
case LatencyType.P9999:
return metric_1.MetricStatistic.P9999;
case LatencyType.P100:
return metric_1.MetricStatistic.P100;
case LatencyType.TM50:
return metric_1.MetricStatistic.TM50;
case LatencyType.TM70:
return metric_1.MetricStatistic.TM70;
case LatencyType.TM90:
return metric_1.MetricStatistic.TM90;
case LatencyType.TM95:
return metric_1.MetricStatistic.TM95;
case LatencyType.TM99:
return metric_1.MetricStatistic.TM99;
case LatencyType.TM999:
return metric_1.MetricStatistic.TM999;
case LatencyType.TM9999:
return metric_1.MetricStatistic.TM9999;
case LatencyType.TM95_TOP:
return metric_1.MetricStatistic.TM95_TOP;
case LatencyType.TM99_TOP:
return metric_1.MetricStatistic.TM99_TOP;
case LatencyType.TM999_TOP:
return metric_1.MetricStatistic.TM999_TOP;
case LatencyType.TM9999_TOP:
return metric_1.MetricStatistic.TM9999_TOP;
case LatencyType.AVERAGE:
return metric_1.MetricStatistic.AVERAGE;
case LatencyType.MAX:
return metric_1.MetricStatistic.MAX;
default:
throw new Error("Unsupported latency type (unknown statistic): " + latencyType);
}
}
exports.getLatencyTypeStatistic = getLatencyTypeStatistic;
function getLatencyTypeExpressionId(latencyType) {
switch (latencyType) {
case LatencyType.P50:
case LatencyType.P70:
case LatencyType.P90:
case LatencyType.P95:
case LatencyType.P99:
case LatencyType.P999:
case LatencyType.P9999:
case LatencyType.P100:
// remove the P prefix
return latencyType.substring(1);
case LatencyType.AVERAGE:
// making it shorter for backwards compatibility
return "Avg";
case LatencyType.MAX:
return "Max";
default:
// use as-is
return latencyType;
}
}
exports.getLatencyTypeExpressionId = getLatencyTypeExpressionId;
function getLatencyTypeLabel(latencyType) {
const averageSuffix = " (avg: ${AVG})";
switch (latencyType) {
case LatencyType.P999:
case LatencyType.TM999:
// we need proper decimal here
return latencyType.replace("999", "99.9") + averageSuffix;
case LatencyType.P9999:
case LatencyType.TM9999:
case LatencyType.TM95_TOP:
case LatencyType.TM99_TOP:
case LatencyType.TM999_TOP:
case LatencyType.TM9999_TOP:
// we need proper decimal here
return latencyType.replace("9999", "99.99") + averageSuffix;
case LatencyType.AVERAGE:
// no suffix here, since we already have average
return "Average";
case LatencyType.MAX:
return "Maximum";
default:
// use as-is
return latencyType + averageSuffix;
}
}
exports.getLatencyTypeLabel = getLatencyTypeLabel;
class LatencyAlarmFactory {
constructor(alarmFactory) {
this.alarmFactory = alarmFactory;
}
addLatencyAlarm(metric, latencyType, props, disambiguator, additionalAlarmNameSuffix = undefined) {
const alarmNameSuffix = ["Latency", latencyType, additionalAlarmNameSuffix]
.filter((i) => i !== undefined)
.join("-");
return this.alarmFactory.addAlarm(metric, {
treatMissingData: props.treatMissingDataOverride ?? aws_cloudwatch_1.TreatMissingData.NOT_BREACHING,
comparisonOperator: props.comparisonOperatorOverride ??
aws_cloudwatch_1.ComparisonOperator.GREATER_THAN_THRESHOLD,
...props,
disambiguator,
threshold: props.maxLatency.toMilliseconds({ integral: false }),
alarmNameSuffix,
// we will dedupe any kind of latency issue to the same ticket
alarmDedupeStringSuffix: this.alarmFactory
.shouldUseDefaultDedupeForLatency
? "AnyLatency"
: alarmNameSuffix,
alarmDescription: `${latencyType} latency is too high.`,
});
}
addIntegrationLatencyAlarm(metric, latencyType, props, disambiguator, additionalAlarmNameSuffix = undefined) {
const alarmNameSuffix = [
"IntegrationLatency",
latencyType,
additionalAlarmNameSuffix,
]
.filter((i) => i !== undefined)
.join("-");
return this.alarmFactory.addAlarm(metric, {
treatMissingData: props.treatMissingDataOverride ?? aws_cloudwatch_1.TreatMissingData.NOT_BREACHING,
comparisonOperator: props.comparisonOperatorOverride ??
aws_cloudwatch_1.ComparisonOperator.GREATER_THAN_THRESHOLD,
...props,
disambiguator,
threshold: props.maxLatency.toMilliseconds({ integral: false }),
alarmNameSuffix,
// we will dedupe any kind of latency issue to the same alarm
alarmDedupeStringSuffix: this.alarmFactory
.shouldUseDefaultDedupeForLatency
? "AnyLatency"
: alarmNameSuffix,
alarmDescription: `${latencyType} integration latency is too high.`,
});
}
addDurationAlarm(metric, latencyType, props, disambiguator, additionalAlarmNameSuffix = undefined) {
const alarmNameSuffix = ["Duration", latencyType, additionalAlarmNameSuffix]
.filter((i) => i !== undefined)
.join("-");
return this.alarmFactory.addAlarm(metric, {
treatMissingData: props.treatMissingDataOverride ?? aws_cloudwatch_1.TreatMissingData.NOT_BREACHING,
comparisonOperator: props.comparisonOperatorOverride ??
aws_cloudwatch_1.ComparisonOperator.GREATER_THAN_THRESHOLD,
...props,
disambiguator,
threshold: props.maxDuration.toMilliseconds({ integral: false }),
alarmNameSuffix,
// we will dedupe any kind of latency issue to the same ticket
alarmDedupeStringSuffix: this.alarmFactory
.shouldUseDefaultDedupeForLatency
? "AnyDuration"
: alarmNameSuffix,
alarmDescription: `${latencyType} duration is too long.`,
});
}
addCustomDurationAlarm(metric, latencyType, props, durationName, disambiguator, additionalAlarmNameSuffix = undefined) {
const alarmNameSuffix = [
durationName,
latencyType,
additionalAlarmNameSuffix,
]
.filter((i) => i !== undefined)
.join("-");
return this.alarmFactory.addAlarm(metric, {
treatMissingData: props.treatMissingDataOverride ?? aws_cloudwatch_1.TreatMissingData.NOT_BREACHING,
comparisonOperator: props.comparisonOperatorOverride ??
aws_cloudwatch_1.ComparisonOperator.GREATER_THAN_THRESHOLD,
...props,
disambiguator,
threshold: props.maxDuration.toMilliseconds({ integral: false }),
alarmNameSuffix,
// we will dedupe any kind of latency issue to the same ticket
alarmDedupeStringSuffix: this.alarmFactory
.shouldUseDefaultDedupeForLatency
? `Any${durationName}`
: alarmNameSuffix,
alarmDescription: `${latencyType} ${durationName} is too long.`,
});
}
addJvmGarbageCollectionDurationAlarm(metric, latencyType, props, disambiguator, additionalAlarmNameSuffix = undefined) {
const alarmNameSuffix = [
"Garbage-Collection-Time",
latencyType,
additionalAlarmNameSuffix,
]
.filter((i) => i !== undefined)
.join("-");
return this.alarmFactory.addAlarm(metric, {
treatMissingData: props.treatMissingDataOverride ?? aws_cloudwatch_1.TreatMissingData.NOT_BREACHING,
comparisonOperator: props.comparisonOperatorOverride ??
aws_cloudwatch_1.ComparisonOperator.GREATER_THAN_THRESHOLD,
...props,
disambiguator,
threshold: props.maxDuration.toMilliseconds({ integral: false }),
alarmNameSuffix,
// we will dedupe any kind of latency issue to the same ticket
alarmDedupeStringSuffix: this.alarmFactory
.shouldUseDefaultDedupeForLatency
? "AnyDuration"
: alarmNameSuffix,
alarmDescription: `${latencyType} duration is too long.`,
});
}
}
exports.LatencyAlarmFactory = LatencyAlarmFactory;
_a = JSII_RTTI_SYMBOL_1;
LatencyAlarmFactory[_a] = { fqn: "cdk-monitoring-constructs.LatencyAlarmFactory", version: "9.15.2" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"LatencyAlarmFactory.js","sourceRoot":"","sources":["LatencyAlarmFactory.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from \"aws-cdk-lib\";\nimport {\n  ComparisonOperator,\n  TreatMissingData,\n} from \"aws-cdk-lib/aws-cloudwatch\";\n\nimport { AlarmFactory, CustomAlarmThreshold } from \"../../alarm\";\nimport { MetricStatistic, MetricWithAlarmSupport } from \"../../metric\";\n\nexport enum LatencyType {\n  P50 = \"P50\",\n  P70 = \"P70\",\n  P90 = \"P90\",\n  P95 = \"P95\",\n  P99 = \"P99\",\n  P999 = \"P999\",\n  P9999 = \"P9999\",\n  P100 = \"P100\",\n  TM50 = \"TM50\",\n  TM70 = \"TM70\",\n  TM90 = \"TM90\",\n  TM95 = \"TM95\",\n  TM99 = \"TM99\",\n  TM999 = \"TM999\",\n  TM9999 = \"TM9999\",\n  TM95_TOP = \"TM(95%:100%)\",\n  TM99_TOP = \"TM(99%:100%)\",\n  TM999_TOP = \"TM(99.9%:100%)\",\n  TM9999_TOP = \"TM(99.99%:100%)\",\n  AVERAGE = \"Average\",\n  MAX = \"Maximum\",\n}\n\nexport function getLatencyTypeStatistic(latencyType: LatencyType) {\n  switch (latencyType) {\n    case LatencyType.P50:\n      return MetricStatistic.P50;\n    case LatencyType.P70:\n      return MetricStatistic.P70;\n    case LatencyType.P90:\n      return MetricStatistic.P90;\n    case LatencyType.P95:\n      return MetricStatistic.P95;\n    case LatencyType.P99:\n      return MetricStatistic.P99;\n    case LatencyType.P999:\n      return MetricStatistic.P999;\n    case LatencyType.P9999:\n      return MetricStatistic.P9999;\n    case LatencyType.P100:\n      return MetricStatistic.P100;\n    case LatencyType.TM50:\n      return MetricStatistic.TM50;\n    case LatencyType.TM70:\n      return MetricStatistic.TM70;\n    case LatencyType.TM90:\n      return MetricStatistic.TM90;\n    case LatencyType.TM95:\n      return MetricStatistic.TM95;\n    case LatencyType.TM99:\n      return MetricStatistic.TM99;\n    case LatencyType.TM999:\n      return MetricStatistic.TM999;\n    case LatencyType.TM9999:\n      return MetricStatistic.TM9999;\n    case LatencyType.TM95_TOP:\n      return MetricStatistic.TM95_TOP;\n    case LatencyType.TM99_TOP:\n      return MetricStatistic.TM99_TOP;\n    case LatencyType.TM999_TOP:\n      return MetricStatistic.TM999_TOP;\n    case LatencyType.TM9999_TOP:\n      return MetricStatistic.TM9999_TOP;\n    case LatencyType.AVERAGE:\n      return MetricStatistic.AVERAGE;\n    case LatencyType.MAX:\n      return MetricStatistic.MAX;\n    default:\n      throw new Error(\n        \"Unsupported latency type (unknown statistic): \" + latencyType,\n      );\n  }\n}\n\nexport function getLatencyTypeExpressionId(latencyType: LatencyType) {\n  switch (latencyType) {\n    case LatencyType.P50:\n    case LatencyType.P70:\n    case LatencyType.P90:\n    case LatencyType.P95:\n    case LatencyType.P99:\n    case LatencyType.P999:\n    case LatencyType.P9999:\n    case LatencyType.P100:\n      // remove the P prefix\n      return latencyType.substring(1);\n    case LatencyType.AVERAGE:\n      // making it shorter for backwards compatibility\n      return \"Avg\";\n    case LatencyType.MAX:\n      return \"Max\";\n    default:\n      // use as-is\n      return latencyType;\n  }\n}\n\nexport function getLatencyTypeLabel(latencyType: LatencyType) {\n  const averageSuffix = \" (avg: ${AVG})\";\n\n  switch (latencyType) {\n    case LatencyType.P999:\n    case LatencyType.TM999:\n      // we need proper decimal here\n      return latencyType.replace(\"999\", \"99.9\") + averageSuffix;\n    case LatencyType.P9999:\n    case LatencyType.TM9999:\n    case LatencyType.TM95_TOP:\n    case LatencyType.TM99_TOP:\n    case LatencyType.TM999_TOP:\n    case LatencyType.TM9999_TOP:\n      // we need proper decimal here\n      return latencyType.replace(\"9999\", \"99.99\") + averageSuffix;\n    case LatencyType.AVERAGE:\n      // no suffix here, since we already have average\n      return \"Average\";\n    case LatencyType.MAX:\n      return \"Maximum\";\n    default:\n      // use as-is\n      return latencyType + averageSuffix;\n  }\n}\n\nexport interface LatencyThreshold extends CustomAlarmThreshold {\n  readonly maxLatency: Duration;\n}\n\nexport interface LatencyTimeoutPercentageThreshold\n  extends CustomAlarmThreshold {\n  readonly maxLatencyPercentageOfTimeout: number;\n}\n\nexport interface DurationThreshold extends CustomAlarmThreshold {\n  readonly maxDuration: Duration;\n}\n\nexport class LatencyAlarmFactory {\n  protected readonly alarmFactory: AlarmFactory;\n\n  constructor(alarmFactory: AlarmFactory) {\n    this.alarmFactory = alarmFactory;\n  }\n\n  addLatencyAlarm(\n    metric: MetricWithAlarmSupport,\n    latencyType: LatencyType,\n    props: LatencyThreshold,\n    disambiguator?: string,\n    additionalAlarmNameSuffix: string | undefined = undefined,\n  ) {\n    const alarmNameSuffix = [\"Latency\", latencyType, additionalAlarmNameSuffix]\n      .filter((i) => i !== undefined)\n      .join(\"-\");\n\n    return this.alarmFactory.addAlarm(metric, {\n      treatMissingData:\n        props.treatMissingDataOverride ?? TreatMissingData.NOT_BREACHING,\n      comparisonOperator:\n        props.comparisonOperatorOverride ??\n        ComparisonOperator.GREATER_THAN_THRESHOLD,\n      ...props,\n      disambiguator,\n      threshold: props.maxLatency.toMilliseconds({ integral: false }),\n      alarmNameSuffix,\n      // we will dedupe any kind of latency issue to the same ticket\n      alarmDedupeStringSuffix: this.alarmFactory\n        .shouldUseDefaultDedupeForLatency\n        ? \"AnyLatency\"\n        : alarmNameSuffix,\n      alarmDescription: `${latencyType} latency is too high.`,\n    });\n  }\n\n  addIntegrationLatencyAlarm(\n    metric: MetricWithAlarmSupport,\n    latencyType: LatencyType,\n    props: LatencyThreshold,\n    disambiguator?: string,\n    additionalAlarmNameSuffix: string | undefined = undefined,\n  ) {\n    const alarmNameSuffix = [\n      \"IntegrationLatency\",\n      latencyType,\n      additionalAlarmNameSuffix,\n    ]\n      .filter((i) => i !== undefined)\n      .join(\"-\");\n\n    return this.alarmFactory.addAlarm(metric, {\n      treatMissingData:\n        props.treatMissingDataOverride ?? TreatMissingData.NOT_BREACHING,\n      comparisonOperator:\n        props.comparisonOperatorOverride ??\n        ComparisonOperator.GREATER_THAN_THRESHOLD,\n      ...props,\n      disambiguator,\n      threshold: props.maxLatency.toMilliseconds({ integral: false }),\n      alarmNameSuffix,\n      // we will dedupe any kind of latency issue to the same alarm\n      alarmDedupeStringSuffix: this.alarmFactory\n        .shouldUseDefaultDedupeForLatency\n        ? \"AnyLatency\"\n        : alarmNameSuffix,\n      alarmDescription: `${latencyType} integration latency is too high.`,\n    });\n  }\n\n  addDurationAlarm(\n    metric: MetricWithAlarmSupport,\n    latencyType: LatencyType,\n    props: DurationThreshold,\n    disambiguator?: string,\n    additionalAlarmNameSuffix: string | undefined = undefined,\n  ) {\n    const alarmNameSuffix = [\"Duration\", latencyType, additionalAlarmNameSuffix]\n      .filter((i) => i !== undefined)\n      .join(\"-\");\n\n    return this.alarmFactory.addAlarm(metric, {\n      treatMissingData:\n        props.treatMissingDataOverride ?? TreatMissingData.NOT_BREACHING,\n      comparisonOperator:\n        props.comparisonOperatorOverride ??\n        ComparisonOperator.GREATER_THAN_THRESHOLD,\n      ...props,\n      disambiguator,\n      threshold: props.maxDuration.toMilliseconds({ integral: false }),\n      alarmNameSuffix,\n      // we will dedupe any kind of latency issue to the same ticket\n      alarmDedupeStringSuffix: this.alarmFactory\n        .shouldUseDefaultDedupeForLatency\n        ? \"AnyDuration\"\n        : alarmNameSuffix,\n      alarmDescription: `${latencyType} duration is too long.`,\n    });\n  }\n\n  addCustomDurationAlarm(\n    metric: MetricWithAlarmSupport,\n    latencyType: LatencyType,\n    props: DurationThreshold,\n    durationName: string,\n    disambiguator?: string,\n    additionalAlarmNameSuffix: string | undefined = undefined,\n  ) {\n    const alarmNameSuffix = [\n      durationName,\n      latencyType,\n      additionalAlarmNameSuffix,\n    ]\n      .filter((i) => i !== undefined)\n      .join(\"-\");\n\n    return this.alarmFactory.addAlarm(metric, {\n      treatMissingData:\n        props.treatMissingDataOverride ?? TreatMissingData.NOT_BREACHING,\n      comparisonOperator:\n        props.comparisonOperatorOverride ??\n        ComparisonOperator.GREATER_THAN_THRESHOLD,\n      ...props,\n      disambiguator,\n      threshold: props.maxDuration.toMilliseconds({ integral: false }),\n      alarmNameSuffix,\n      // we will dedupe any kind of latency issue to the same ticket\n      alarmDedupeStringSuffix: this.alarmFactory\n        .shouldUseDefaultDedupeForLatency\n        ? `Any${durationName}`\n        : alarmNameSuffix,\n      alarmDescription: `${latencyType} ${durationName} is too long.`,\n    });\n  }\n\n  addJvmGarbageCollectionDurationAlarm(\n    metric: MetricWithAlarmSupport,\n    latencyType: LatencyType,\n    props: DurationThreshold,\n    disambiguator?: string,\n    additionalAlarmNameSuffix: string | undefined = undefined,\n  ) {\n    const alarmNameSuffix = [\n      \"Garbage-Collection-Time\",\n      latencyType,\n      additionalAlarmNameSuffix,\n    ]\n      .filter((i) => i !== undefined)\n      .join(\"-\");\n\n    return this.alarmFactory.addAlarm(metric, {\n      treatMissingData:\n        props.treatMissingDataOverride ?? TreatMissingData.NOT_BREACHING,\n      comparisonOperator:\n        props.comparisonOperatorOverride ??\n        ComparisonOperator.GREATER_THAN_THRESHOLD,\n      ...props,\n      disambiguator,\n      threshold: props.maxDuration.toMilliseconds({ integral: false }),\n      alarmNameSuffix,\n      // we will dedupe any kind of latency issue to the same ticket\n      alarmDedupeStringSuffix: this.alarmFactory\n        .shouldUseDefaultDedupeForLatency\n        ? \"AnyDuration\"\n        : alarmNameSuffix,\n      alarmDescription: `${latencyType} duration is too long.`,\n    });\n  }\n}\n"]}