UNPKG

cdk-monitoring-constructs

Version:

[![NPM version](https://badge.fury.io/js/cdk-monitoring-constructs.svg)](https://badge.fury.io/js/cdk-monitoring-constructs) [![Maven Central](https://maven-badges.herokuapp.com/maven-central/io.github.cdklabs/cdkmonitoringconstructs/badge.svg)](https://m

250 lines 33 kB
"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"]}