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

84 lines 12.3 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.RdsInstanceMetricFactory = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const common_1 = require("../../common"); const RdsNamespace = "AWS/RDS"; class RdsInstanceMetricFactory extends common_1.BaseMetricFactory { constructor(metricFactory, props) { super(metricFactory, props); this.instance = props.instance; this.instanceIdentifier = props.instance.instanceIdentifier; this.dimensionsMap = { DBInstanceIdentifier: this.instanceIdentifier, }; } metricTotalConnectionCount() { return this.metricFactory.adaptMetric(this.instance.metricDatabaseConnections({ statistic: common_1.MetricStatistic.SUM, label: "Connections: Sum", region: this.region, account: this.account, })); } metricAverageCpuUsageInPercent() { return this.metricFactory.adaptMetric(this.instance.metricCPUUtilization({ statistic: common_1.MetricStatistic.AVERAGE, label: "CPU Usage", region: this.region, account: this.account, })); } metricMaxFreeStorageSpace() { return this.metricFactory.adaptMetric(this.instance.metricFreeStorageSpace({ statistic: common_1.MetricStatistic.MAX, label: "FreeStorageSpace: MAX", region: this.region, account: this.account, })); } metricAverageFreeableMemory() { return this.metricFactory.adaptMetric(this.instance.metricFreeableMemory({ statistic: common_1.MetricStatistic.AVERAGE, label: "FreeStorageSpace: Average", region: this.region, account: this.account, })); } metricReadLatencyInMillis(latencyType) { return this.metric("ReadLatency", common_1.getLatencyTypeStatistic(latencyType), `ReadLatency ${common_1.getLatencyTypeLabel(latencyType)}`); } metricReadThroughput() { return this.metric("ReadThroughput", common_1.MetricStatistic.AVERAGE, "ReadThroughput: Average"); } metricReadIops() { return this.metricFactory.adaptMetric(this.instance.metricReadIOPS({ statistic: common_1.MetricStatistic.AVERAGE, label: "ReadIOPS: Average", region: this.region, account: this.account, })); } metricWriteLatencyInMillis(latencyType) { return this.metric("WriteLatency", common_1.getLatencyTypeStatistic(latencyType), `WriteLatency ${common_1.getLatencyTypeLabel(latencyType)}`); } metricWriteThroughput() { return this.metric("WriteThroughput", common_1.MetricStatistic.AVERAGE, "WriteThroughput: Average"); } metricWriteIops() { return this.metricFactory.adaptMetric(this.instance.metricWriteIOPS({ statistic: common_1.MetricStatistic.AVERAGE, label: "WriteIOPS: Average", region: this.region, account: this.account, })); } metric(metricName, statistic, label) { return this.metricFactory.createMetric(metricName, statistic, label, this.dimensionsMap, undefined, RdsNamespace, undefined, this.region, this.account); } } exports.RdsInstanceMetricFactory = RdsInstanceMetricFactory; _a = JSII_RTTI_SYMBOL_1; RdsInstanceMetricFactory[_a] = { fqn: "cdk-monitoring-constructs.RdsInstanceMetricFactory", version: "9.15.2" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RdsInstanceMetricFactory.js","sourceRoot":"","sources":["RdsInstanceMetricFactory.ts"],"names":[],"mappings":"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","sourcesContent":["import { DimensionsMap } from \"aws-cdk-lib/aws-cloudwatch\";\nimport { IDatabaseInstance } from \"aws-cdk-lib/aws-rds\";\n\nimport {\n  BaseMetricFactory,\n  BaseMetricFactoryProps,\n  LatencyType,\n  MetricFactory,\n  MetricStatistic,\n  getLatencyTypeLabel,\n  getLatencyTypeStatistic,\n} from \"../../common\";\n\nconst RdsNamespace = \"AWS/RDS\";\n\nexport interface RdsInstanceMetricFactoryProps extends BaseMetricFactoryProps {\n  /**\n   * database instance\n   */\n  readonly instance: IDatabaseInstance;\n}\n\nexport class RdsInstanceMetricFactory extends BaseMetricFactory<RdsInstanceMetricFactoryProps> {\n  readonly instanceIdentifier: string;\n  readonly instance: IDatabaseInstance;\n  protected readonly dimensionsMap: DimensionsMap;\n\n  constructor(\n    metricFactory: MetricFactory,\n    props: RdsInstanceMetricFactoryProps,\n  ) {\n    super(metricFactory, props);\n\n    this.instance = props.instance;\n    this.instanceIdentifier = props.instance.instanceIdentifier;\n    this.dimensionsMap = {\n      DBInstanceIdentifier: this.instanceIdentifier,\n    };\n  }\n\n  metricTotalConnectionCount() {\n    return this.metricFactory.adaptMetric(\n      this.instance.metricDatabaseConnections({\n        statistic: MetricStatistic.SUM,\n        label: \"Connections: Sum\",\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricAverageCpuUsageInPercent() {\n    return this.metricFactory.adaptMetric(\n      this.instance.metricCPUUtilization({\n        statistic: MetricStatistic.AVERAGE,\n        label: \"CPU Usage\",\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricMaxFreeStorageSpace() {\n    return this.metricFactory.adaptMetric(\n      this.instance.metricFreeStorageSpace({\n        statistic: MetricStatistic.MAX,\n        label: \"FreeStorageSpace: MAX\",\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricAverageFreeableMemory() {\n    return this.metricFactory.adaptMetric(\n      this.instance.metricFreeableMemory({\n        statistic: MetricStatistic.AVERAGE,\n        label: \"FreeStorageSpace: Average\",\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricReadLatencyInMillis(latencyType: LatencyType) {\n    return this.metric(\n      \"ReadLatency\",\n      getLatencyTypeStatistic(latencyType),\n      `ReadLatency ${getLatencyTypeLabel(latencyType)}`,\n    );\n  }\n\n  metricReadThroughput() {\n    return this.metric(\n      \"ReadThroughput\",\n      MetricStatistic.AVERAGE,\n      \"ReadThroughput: Average\",\n    );\n  }\n\n  metricReadIops() {\n    return this.metricFactory.adaptMetric(\n      this.instance.metricReadIOPS({\n        statistic: MetricStatistic.AVERAGE,\n        label: \"ReadIOPS: Average\",\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricWriteLatencyInMillis(latencyType: LatencyType) {\n    return this.metric(\n      \"WriteLatency\",\n      getLatencyTypeStatistic(latencyType),\n      `WriteLatency ${getLatencyTypeLabel(latencyType)}`,\n    );\n  }\n\n  metricWriteThroughput() {\n    return this.metric(\n      \"WriteThroughput\",\n      MetricStatistic.AVERAGE,\n      \"WriteThroughput: Average\",\n    );\n  }\n\n  metricWriteIops() {\n    return this.metricFactory.adaptMetric(\n      this.instance.metricWriteIOPS({\n        statistic: MetricStatistic.AVERAGE,\n        label: \"WriteIOPS: Average\",\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  private metric(\n    metricName: string,\n    statistic: MetricStatistic,\n    label: string,\n  ) {\n    return this.metricFactory.createMetric(\n      metricName,\n      statistic,\n      label,\n      this.dimensionsMap,\n      undefined,\n      RdsNamespace,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n}\n"]}