cdk-monitoring-constructs
Version:
[](https://badge.fury.io/js/cdk-monitoring-constructs) [](https://m
210 lines • 17.8 kB
JavaScript
"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"]}