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

210 lines 17.8 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.OpenSearchBackportedMetrics = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const aws_cdk_lib_1 = require("aws-cdk-lib"); const aws_cloudwatch_1 = require("aws-cdk-lib/aws-cloudwatch"); const ElasticsearchNamespace = "AWS/ES"; /** * Backported set of metric functions added in @aws-cdk/aws-elasticsearch@1.65.0. * @see https://github.com/aws/aws-cdk/pull/8369 * * TODO: can be removed after upgrade to 1.73.0, which includes bugfixes for the * latency p99 metrics. * @see https://github.com/aws/aws-cdk/releases/tag/v1.73.0 */ class OpenSearchBackportedMetrics { constructor(domain) { this.dimensionsMap = { ClientId: domain.stack.account, DomainName: domain.domainName, }; } /** * Return the given named metric for this Domain. */ metric(metricName, props) { return new aws_cloudwatch_1.Metric({ namespace: ElasticsearchNamespace, metricName, dimensionsMap: this.dimensionsMap, ...props, }); } /** * Metric for the time the cluster status is red. * * @default - maximum over 5 minutes */ metricClusterStatusRed(props) { return this.metric("ClusterStatus.red", { statistic: aws_cloudwatch_1.Stats.MAXIMUM, ...props, }); } /** * Metric for the time the cluster status is yellow. * * @default - maximum over 5 minutes */ metricClusterStatusYellow(props) { return this.metric("ClusterStatus.yellow", { statistic: aws_cloudwatch_1.Stats.MAXIMUM, ...props, }); } /** * Metric for the storage space of nodes in the cluster. * * @default - minimum over 5 minutes */ metricFreeStorageSpace(props) { return this.metric("FreeStorageSpace", { statistic: aws_cloudwatch_1.Stats.MINIMUM, ...props, }); } /** * Metric for the cluster blocking index writes. * * @default - maximum over 1 minute */ metricClusterIndexWritesBlocked(props) { return this.metric("ClusterIndexWritesBlocked", { statistic: aws_cloudwatch_1.Stats.MAXIMUM, period: aws_cdk_lib_1.Duration.minutes(1), ...props, }); } /** * Metric for the cluster blocking index writes. * * @default - maximum over 1 minute * * @deprecated use metricClusterIndexWritesBlocked instead. */ metricClusterIndexWriteBlocked(props) { return this.metricClusterIndexWritesBlocked(props); } /** * Metric for the number of nodes. * * @default - minimum over 1 hour */ metricNodes(props) { return this.metric("Nodes", { statistic: aws_cloudwatch_1.Stats.MINIMUM, period: aws_cdk_lib_1.Duration.hours(1), ...props, }); } /** * Metric for automated snapshot failures. * * @default - maximum over 5 minutes */ metricAutomatedSnapshotFailure(props) { return this.metric("AutomatedSnapshotFailure", { statistic: aws_cloudwatch_1.Stats.MAXIMUM, ...props, }); } /** * Metric for CPU utilization. * * @default - maximum over 5 minutes */ metricCPUUtilization(props) { return this.metric("CPUUtilization", { statistic: aws_cloudwatch_1.Stats.MAXIMUM, ...props, }); } /** * Metric for JVM memory pressure. * * @default - maximum over 5 minutes */ metricJVMMemoryPressure(props) { return this.metric("JVMMemoryPressure", { statistic: aws_cloudwatch_1.Stats.MAXIMUM, ...props, }); } /** * Metric for master CPU utilization. * * @default - maximum over 5 minutes */ metricMasterCPUUtilization(props) { return this.metric("MasterCPUUtilization", { statistic: aws_cloudwatch_1.Stats.MAXIMUM, ...props, }); } /** * Metric for master JVM memory pressure. * * @default - maximum over 5 minutes */ metricMasterJVMMemoryPressure(props) { return this.metric("MasterJVMMemoryPressure", { statistic: aws_cloudwatch_1.Stats.MAXIMUM, ...props, }); } /** * Metric for KMS key errors. * * @default - maximum over 5 minutes */ metricKMSKeyError(props) { return this.metric("KMSKeyError", { statistic: aws_cloudwatch_1.Stats.MAXIMUM, ...props, }); } /** * Metric for KMS key being inaccessible. * * @default - maximum over 5 minutes */ metricKMSKeyInaccessible(props) { return this.metric("KMSKeyInaccessible", { statistic: aws_cloudwatch_1.Stats.MAXIMUM, ...props, }); } /** * Metric for number of searchable documents. * * @default - maximum over 5 minutes */ metricSearchableDocuments(props) { return this.metric("SearchableDocuments", { statistic: aws_cloudwatch_1.Stats.MAXIMUM, ...props, }); } /** * Metric for search latency. * * @default - p99 over 5 minutes */ metricSearchLatency(props) { return this.metric("SearchLatency", { statistic: "p99", ...props }); } /** * Metric for indexing latency. * * @default - p99 over 5 minutes */ metricIndexingLatency(props) { return this.metric("IndexingLatency", { statistic: "p99", ...props }); } } exports.OpenSearchBackportedMetrics = OpenSearchBackportedMetrics; _a = JSII_RTTI_SYMBOL_1; OpenSearchBackportedMetrics[_a] = { fqn: "cdk-monitoring-constructs.OpenSearchBackportedMetrics", version: "9.15.2" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"OpenSearchBackportedMetrics.js","sourceRoot":"","sources":["OpenSearchBackportedMetrics.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from \"aws-cdk-lib\";\nimport {\n  DimensionsMap,\n  Metric,\n  MetricOptions,\n  Stats,\n} from \"aws-cdk-lib/aws-cloudwatch\";\nimport * as elasticsearch from \"aws-cdk-lib/aws-elasticsearch\";\nimport * as opensearch from \"aws-cdk-lib/aws-opensearchservice\";\n\nconst ElasticsearchNamespace = \"AWS/ES\";\n\nexport type Domain =\n  | opensearch.CfnDomain\n  | opensearch.IDomain\n  | elasticsearch.CfnDomain\n  | elasticsearch.IDomain;\n\n/**\n * Backported set of metric functions added in @aws-cdk/aws-elasticsearch@1.65.0.\n * @see https://github.com/aws/aws-cdk/pull/8369\n *\n * TODO: can be removed after upgrade to 1.73.0, which includes bugfixes for the\n * latency p99 metrics.\n * @see https://github.com/aws/aws-cdk/releases/tag/v1.73.0\n */\nexport class OpenSearchBackportedMetrics {\n  protected readonly dimensionsMap: DimensionsMap;\n\n  constructor(domain: Domain) {\n    this.dimensionsMap = {\n      ClientId: domain.stack.account,\n      DomainName: domain.domainName!,\n    };\n  }\n\n  /**\n   * Return the given named metric for this Domain.\n   */\n  metric(metricName: string, props?: MetricOptions): Metric {\n    return new Metric({\n      namespace: ElasticsearchNamespace,\n      metricName,\n      dimensionsMap: this.dimensionsMap,\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for the time the cluster status is red.\n   *\n   * @default - maximum over 5 minutes\n   */\n  metricClusterStatusRed(props?: MetricOptions): Metric {\n    return this.metric(\"ClusterStatus.red\", {\n      statistic: Stats.MAXIMUM,\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for the time the cluster status is yellow.\n   *\n   * @default - maximum over 5 minutes\n   */\n  metricClusterStatusYellow(props?: MetricOptions): Metric {\n    return this.metric(\"ClusterStatus.yellow\", {\n      statistic: Stats.MAXIMUM,\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for the storage space of nodes in the cluster.\n   *\n   * @default - minimum over 5 minutes\n   */\n  metricFreeStorageSpace(props?: MetricOptions): Metric {\n    return this.metric(\"FreeStorageSpace\", {\n      statistic: Stats.MINIMUM,\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for the cluster blocking index writes.\n   *\n   * @default - maximum over 1 minute\n   */\n  metricClusterIndexWritesBlocked(props?: MetricOptions): Metric {\n    return this.metric(\"ClusterIndexWritesBlocked\", {\n      statistic: Stats.MAXIMUM,\n      period: Duration.minutes(1),\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for the cluster blocking index writes.\n   *\n   * @default - maximum over 1 minute\n   *\n   * @deprecated use metricClusterIndexWritesBlocked instead.\n   */\n  metricClusterIndexWriteBlocked(props?: MetricOptions): Metric {\n    return this.metricClusterIndexWritesBlocked(props);\n  }\n\n  /**\n   * Metric for the number of nodes.\n   *\n   * @default - minimum over 1 hour\n   */\n  metricNodes(props?: MetricOptions): Metric {\n    return this.metric(\"Nodes\", {\n      statistic: Stats.MINIMUM,\n      period: Duration.hours(1),\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for automated snapshot failures.\n   *\n   * @default - maximum over 5 minutes\n   */\n  metricAutomatedSnapshotFailure(props?: MetricOptions): Metric {\n    return this.metric(\"AutomatedSnapshotFailure\", {\n      statistic: Stats.MAXIMUM,\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for CPU utilization.\n   *\n   * @default - maximum over 5 minutes\n   */\n  metricCPUUtilization(props?: MetricOptions): Metric {\n    return this.metric(\"CPUUtilization\", {\n      statistic: Stats.MAXIMUM,\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for JVM memory pressure.\n   *\n   * @default - maximum over 5 minutes\n   */\n  metricJVMMemoryPressure(props?: MetricOptions): Metric {\n    return this.metric(\"JVMMemoryPressure\", {\n      statistic: Stats.MAXIMUM,\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for master CPU utilization.\n   *\n   * @default - maximum over 5 minutes\n   */\n  metricMasterCPUUtilization(props?: MetricOptions): Metric {\n    return this.metric(\"MasterCPUUtilization\", {\n      statistic: Stats.MAXIMUM,\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for master JVM memory pressure.\n   *\n   * @default - maximum over 5 minutes\n   */\n  metricMasterJVMMemoryPressure(props?: MetricOptions): Metric {\n    return this.metric(\"MasterJVMMemoryPressure\", {\n      statistic: Stats.MAXIMUM,\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for KMS key errors.\n   *\n   * @default - maximum over 5 minutes\n   */\n  metricKMSKeyError(props?: MetricOptions): Metric {\n    return this.metric(\"KMSKeyError\", {\n      statistic: Stats.MAXIMUM,\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for KMS key being inaccessible.\n   *\n   * @default - maximum over 5 minutes\n   */\n  metricKMSKeyInaccessible(props?: MetricOptions): Metric {\n    return this.metric(\"KMSKeyInaccessible\", {\n      statistic: Stats.MAXIMUM,\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for number of searchable documents.\n   *\n   * @default - maximum over 5 minutes\n   */\n  metricSearchableDocuments(props?: MetricOptions): Metric {\n    return this.metric(\"SearchableDocuments\", {\n      statistic: Stats.MAXIMUM,\n      ...props,\n    });\n  }\n\n  /**\n   * Metric for search latency.\n   *\n   * @default - p99 over 5 minutes\n   */\n  metricSearchLatency(props?: MetricOptions): Metric {\n    return this.metric(\"SearchLatency\", { statistic: \"p99\", ...props });\n  }\n\n  /**\n   * Metric for indexing latency.\n   *\n   * @default - p99 over 5 minutes\n   */\n  metricIndexingLatency(props?: MetricOptions): Metric {\n    return this.metric(\"IndexingLatency\", { statistic: \"p99\", ...props });\n  }\n}\n"]}