cdk-monitoring-constructs
Version:
[](https://badge.fury.io/js/cdk-monitoring-constructs) [](https://m
69 lines • 14.6 kB
JavaScript
"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.ElastiCacheClusterMetricFactory = exports.ElastiCacheClusterType = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const common_1 = require("../../common");
const Namespace = "AWS/ElastiCache";
var ElastiCacheClusterType;
(function (ElastiCacheClusterType) {
ElastiCacheClusterType[ElastiCacheClusterType["MEMCACHED"] = 0] = "MEMCACHED";
ElastiCacheClusterType[ElastiCacheClusterType["REDIS"] = 1] = "REDIS";
})(ElastiCacheClusterType = exports.ElastiCacheClusterType || (exports.ElastiCacheClusterType = {}));
/**
* @see https://docs.aws.amazon.com/AmazonElastiCache/latest/mem-ug/CacheMetrics.html
*/
class ElastiCacheClusterMetricFactory extends common_1.BaseMetricFactory {
constructor(metricFactory, props) {
super(metricFactory, props);
this.dimensionsMap = {};
if (props.clusterId) {
this.dimensionsMap.CacheClusterId = props.clusterId;
}
}
metricMaxItemCount() {
return this.metricFactory.createMetric("CurrItems", common_1.MetricStatistic.MAX, "Count", this.dimensionsMap, undefined, Namespace, undefined, this.region, this.account);
}
metricEvictions() {
return this.metricFactory.createMetric("Evictions", common_1.MetricStatistic.SUM, "Evictions", this.dimensionsMap, undefined, Namespace, undefined, this.region, this.account);
}
metricAverageFreeableMemoryInBytes() {
return this.metricFactory.createMetric("FreeableMemory", common_1.MetricStatistic.AVERAGE, "Freeable", this.dimensionsMap, undefined, Namespace, undefined, this.region, this.account);
}
metricAverageUnusedMemoryInBytes() {
return this.metricFactory.createMetric("UnusedMemory", common_1.MetricStatistic.AVERAGE, "Unused", this.dimensionsMap, undefined, Namespace, undefined, this.region, this.account);
}
metricAverageCachedItemsSizeInBytes() {
return this.metricFactory.createMetric("BytesUsedForCacheItems", common_1.MetricStatistic.AVERAGE, "Items", this.dimensionsMap, undefined, Namespace, undefined, this.region, this.account);
}
metricAverageSwapUsageInBytes() {
return this.metricFactory.createMetric("SwapUsage", common_1.MetricStatistic.AVERAGE, "Swap", this.dimensionsMap, undefined, Namespace, undefined, this.region, this.account);
}
metricMaxCpuUtilizationInPercent() {
return this.metricFactory.createMetric("CPUUtilization", common_1.MetricStatistic.MAX, "Cluster CPU Utilization", this.dimensionsMap, undefined, Namespace, undefined, this.region, this.account);
}
/**
* Because Redis is single-threaded, you can use this metric to analyze the load of the Redis process itself.
* Note that you may want to monitor both Engine CPU Utilization as well as CPU Utilization as background
* processes can take up a significant portion of the CPU workload. This is especially important for
* hosts with 2 vCPUs or less.
*
* @see https://docs.aws.amazon.com/AmazonElastiCache/latest/red-ug/CacheMetrics.Redis.html
*/
metricMaxRedisEngineCpuUtilizationInPercent() {
return this.metricFactory.createMetric("EngineCPUUtilization", common_1.MetricStatistic.MAX, "Cluster Engine CPU Utilization", this.dimensionsMap, undefined, Namespace, undefined, this.region, this.account);
}
metricAverageConnections() {
return this.metricFactory.createMetric("CurrConnections", common_1.MetricStatistic.AVERAGE, "Current", this.dimensionsMap, undefined, Namespace, undefined, this.region, this.account);
}
metricNetworkBytesIn() {
return this.metricFactory.createMetric("NetworkBytesIn", common_1.MetricStatistic.SUM, "Bytes In", this.dimensionsMap, undefined, Namespace, undefined, this.region, this.account);
}
metricNetworkBytesOut() {
return this.metricFactory.createMetric("NetworkBytesOut", common_1.MetricStatistic.SUM, "Bytes Out", this.dimensionsMap, undefined, Namespace, undefined, this.region, this.account);
}
}
exports.ElastiCacheClusterMetricFactory = ElastiCacheClusterMetricFactory;
_a = JSII_RTTI_SYMBOL_1;
ElastiCacheClusterMetricFactory[_a] = { fqn: "cdk-monitoring-constructs.ElastiCacheClusterMetricFactory", version: "9.15.2" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ElastiCacheClusterMetricFactory.js","sourceRoot":"","sources":["ElastiCacheClusterMetricFactory.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 Namespace = \"AWS/ElastiCache\";\n\nexport enum ElastiCacheClusterType {\n  MEMCACHED,\n  REDIS,\n}\n\nexport interface ElastiCacheClusterMetricFactoryProps\n  extends BaseMetricFactoryProps {\n  /**\n   * Cluster to monitor\n   * @default - monitor all clusters\n   */\n  readonly clusterId?: string;\n}\n\n/**\n * @see https://docs.aws.amazon.com/AmazonElastiCache/latest/mem-ug/CacheMetrics.html\n */\nexport class ElastiCacheClusterMetricFactory extends BaseMetricFactory<ElastiCacheClusterMetricFactoryProps> {\n  protected readonly dimensionsMap: DimensionsMap;\n\n  constructor(\n    metricFactory: MetricFactory,\n    props: ElastiCacheClusterMetricFactoryProps,\n  ) {\n    super(metricFactory, props);\n\n    this.dimensionsMap = {};\n    if (props.clusterId) {\n      this.dimensionsMap.CacheClusterId = props.clusterId;\n    }\n  }\n\n  metricMaxItemCount() {\n    return this.metricFactory.createMetric(\n      \"CurrItems\",\n      MetricStatistic.MAX,\n      \"Count\",\n      this.dimensionsMap,\n      undefined,\n      Namespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricEvictions() {\n    return this.metricFactory.createMetric(\n      \"Evictions\",\n      MetricStatistic.SUM,\n      \"Evictions\",\n      this.dimensionsMap,\n      undefined,\n      Namespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricAverageFreeableMemoryInBytes() {\n    return this.metricFactory.createMetric(\n      \"FreeableMemory\",\n      MetricStatistic.AVERAGE,\n      \"Freeable\",\n      this.dimensionsMap,\n      undefined,\n      Namespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricAverageUnusedMemoryInBytes() {\n    return this.metricFactory.createMetric(\n      \"UnusedMemory\",\n      MetricStatistic.AVERAGE,\n      \"Unused\",\n      this.dimensionsMap,\n      undefined,\n      Namespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricAverageCachedItemsSizeInBytes() {\n    return this.metricFactory.createMetric(\n      \"BytesUsedForCacheItems\",\n      MetricStatistic.AVERAGE,\n      \"Items\",\n      this.dimensionsMap,\n      undefined,\n      Namespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricAverageSwapUsageInBytes() {\n    return this.metricFactory.createMetric(\n      \"SwapUsage\",\n      MetricStatistic.AVERAGE,\n      \"Swap\",\n      this.dimensionsMap,\n      undefined,\n      Namespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricMaxCpuUtilizationInPercent() {\n    return this.metricFactory.createMetric(\n      \"CPUUtilization\",\n      MetricStatistic.MAX,\n      \"Cluster CPU Utilization\",\n      this.dimensionsMap,\n      undefined,\n      Namespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  /**\n   * Because Redis is single-threaded, you can use this metric to analyze the load of the Redis process itself.\n   * Note that you may want to monitor both Engine CPU Utilization as well as CPU Utilization as background\n   * processes can take up a significant portion of the CPU workload. This is especially important for\n   * hosts with 2 vCPUs or less.\n   *\n   * @see https://docs.aws.amazon.com/AmazonElastiCache/latest/red-ug/CacheMetrics.Redis.html\n   */\n  metricMaxRedisEngineCpuUtilizationInPercent() {\n    return this.metricFactory.createMetric(\n      \"EngineCPUUtilization\",\n      MetricStatistic.MAX,\n      \"Cluster Engine CPU Utilization\",\n      this.dimensionsMap,\n      undefined,\n      Namespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricAverageConnections() {\n    return this.metricFactory.createMetric(\n      \"CurrConnections\",\n      MetricStatistic.AVERAGE,\n      \"Current\",\n      this.dimensionsMap,\n      undefined,\n      Namespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricNetworkBytesIn() {\n    return this.metricFactory.createMetric(\n      \"NetworkBytesIn\",\n      MetricStatistic.SUM,\n      \"Bytes In\",\n      this.dimensionsMap,\n      undefined,\n      Namespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricNetworkBytesOut() {\n    return this.metricFactory.createMetric(\n      \"NetworkBytesOut\",\n      MetricStatistic.SUM,\n      \"Bytes Out\",\n      this.dimensionsMap,\n      undefined,\n      Namespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n}\n"]}