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