cdk-monitoring-constructs
Version:
[](https://badge.fury.io/js/cdk-monitoring-constructs) [](https://m
150 lines • 22.4 kB
JavaScript
"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.DynamoTableMetricFactory = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const aws_dynamodb_1 = require("aws-cdk-lib/aws-dynamodb");
const common_1 = require("../../common");
const DynamoDbNamespace = "AWS/DynamoDB";
const ProvisionedLabel = "Provisioned";
const ConsumedLabel = "Consumed";
const ReadThrottleEventsLabel = "Read";
const WriteThrottleEventsLabel = "Write";
class DynamoTableMetricFactory extends common_1.BaseMetricFactory {
constructor(metricFactory, props) {
super(metricFactory, props);
this.table = props.table;
}
metricProvisionedReadCapacityUnits() {
return this.metricFactory.adaptMetric(this.table.metric("ProvisionedReadCapacityUnits", {
label: ProvisionedLabel,
statistic: common_1.MetricStatistic.AVERAGE,
region: this.region,
account: this.account,
}));
}
metricProvisionedWriteCapacityUnits() {
return this.metricFactory.adaptMetric(this.table.metric("ProvisionedWriteCapacityUnits", {
label: ProvisionedLabel,
statistic: common_1.MetricStatistic.AVERAGE,
region: this.region,
account: this.account,
}));
}
metricConsumedReadCapacityUnits() {
return this.metricFactory.createMetricMath("consumed_rcu_sum/PERIOD(consumed_rcu_sum)", {
consumed_rcu_sum: this.table.metricConsumedReadCapacityUnits({
statistic: common_1.MetricStatistic.SUM,
region: this.region,
account: this.account,
}),
}, ConsumedLabel, undefined, undefined, this.region, this.account);
}
metricConsumedWriteCapacityUnits() {
return this.metricFactory.createMetricMath("consumed_wcu_sum/PERIOD(consumed_wcu_sum)", {
consumed_wcu_sum: this.table.metricConsumedWriteCapacityUnits({
statistic: common_1.MetricStatistic.SUM,
region: this.region,
account: this.account,
}),
}, ConsumedLabel, undefined, undefined, this.region, this.account);
}
metricReadCapacityUtilizationPercentage() {
return this.metricFactory.createMetricMath("100*(consumed_read_cap/provisioned_read_cap)", {
consumed_read_cap: this.metricConsumedReadCapacityUnits(),
provisioned_read_cap: this.metricProvisionedReadCapacityUnits(),
}, "Utilization", undefined, undefined, this.region, this.account);
}
metricWriteCapacityUtilizationPercentage() {
return this.metricFactory.createMetricMath("100*(consumed_write_cap/provisioned_write_cap)", {
consumed_write_cap: this.metricConsumedWriteCapacityUnits(),
provisioned_write_cap: this.metricProvisionedWriteCapacityUnits(),
}, "Utilization", undefined, undefined, this.region, this.account);
}
metricSearchAverageSuccessfulRequestLatencyInMillis() {
// searches for all used operations
return this.metricFactory.createMetricSearch('MetricName="SuccessfulRequestLatency"', {
TableName: this.table.tableName,
Operation: undefined,
}, common_1.MetricStatistic.AVERAGE, DynamoDbNamespace, undefined, undefined, this.region, this.account);
}
metricAverageSuccessfulRequestLatencyInMillis(operation) {
return this.metricFactory.adaptMetric(this.table.metric("SuccessfulRequestLatency", {
statistic: common_1.MetricStatistic.AVERAGE,
label: operation,
dimensionsMap: {
TableName: this.table.tableName,
Operation: operation,
},
region: this.region,
account: this.account,
}));
}
metricThrottledReadRequestCount() {
const readThrottles = this.metricFactory.adaptMetric(this.table.metric("ReadThrottleEvents", {
statistic: common_1.MetricStatistic.SUM,
label: ReadThrottleEventsLabel,
region: this.region,
account: this.account,
}));
return this.metricFactory.createMetricMath("FILL(readThrottles,0)", { readThrottles }, ReadThrottleEventsLabel);
}
metricThrottledWriteRequestCount() {
const writeThrottles = this.metricFactory.adaptMetric(this.table.metric("WriteThrottleEvents", {
statistic: common_1.MetricStatistic.SUM,
label: WriteThrottleEventsLabel,
region: this.region,
account: this.account,
}));
return this.metricFactory.createMetricMath("FILL(writeThrottles,0)", { writeThrottles }, WriteThrottleEventsLabel);
}
/**
* This represents the number of requests that resulted in a 500 (server error) error code.
* It summarizes across the basic CRUD operations:
* GetItem, BatchGetItem, Scan, Query, GetRecords, PutItem, DeleteItem, UpdateItem, BatchWriteItem
*
* It’s usually equal to zero.
*/
metricSystemErrorsCount() {
const crudOperations = [
aws_dynamodb_1.Operation.GET_ITEM,
aws_dynamodb_1.Operation.BATCH_GET_ITEM,
aws_dynamodb_1.Operation.SCAN,
aws_dynamodb_1.Operation.QUERY,
aws_dynamodb_1.Operation.GET_RECORDS,
aws_dynamodb_1.Operation.PUT_ITEM,
aws_dynamodb_1.Operation.DELETE_ITEM,
aws_dynamodb_1.Operation.UPDATE_ITEM,
aws_dynamodb_1.Operation.BATCH_WRITE_ITEM,
];
const usingMetrics = {};
crudOperations.forEach((operation) => {
const metric = this.table.metric("SystemErrors", {
dimensionsMap: {
TableName: this.table.tableName,
Operation: operation,
},
statistic: common_1.MetricStatistic.SUM,
region: this.region,
account: this.account,
});
const metricId = "systemError" + operation;
usingMetrics[metricId] = this.metricFactory.adaptMetric(metric);
});
return this.metricFactory.createMetricMath(
// the metric is not emitted until error happens
Object.keys(usingMetrics).join("+"), usingMetrics, "System Errors");
}
metricTimeToLiveDeletedItemCount() {
return this.metricFactory.adaptMetric(this.table.metric("TimeToLiveDeletedItemCount", {
label: "TTL Deleted Item Count",
statistic: common_1.MetricStatistic.MAX,
region: this.region,
account: this.account,
}));
}
}
exports.DynamoTableMetricFactory = DynamoTableMetricFactory;
_a = JSII_RTTI_SYMBOL_1;
DynamoTableMetricFactory[_a] = { fqn: "cdk-monitoring-constructs.DynamoTableMetricFactory", version: "9.7.1" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DynamoTableMetricFactory.js","sourceRoot":"","sources":["DynamoTableMetricFactory.ts"],"names":[],"mappings":"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","sourcesContent":["import { IMetric } from \"aws-cdk-lib/aws-cloudwatch\";\nimport { BillingMode, ITable, Operation } from \"aws-cdk-lib/aws-dynamodb\";\n\nimport {\n  BaseMetricFactory,\n  BaseMetricFactoryProps,\n  MetricFactory,\n  MetricStatistic,\n} from \"../../common\";\n\nconst DynamoDbNamespace = \"AWS/DynamoDB\";\nconst ProvisionedLabel = \"Provisioned\";\nconst ConsumedLabel = \"Consumed\";\nconst ReadThrottleEventsLabel = \"Read\";\nconst WriteThrottleEventsLabel = \"Write\";\n\nexport interface DynamoTableMetricFactoryProps extends BaseMetricFactoryProps {\n  /**\n   * table to monitor\n   */\n  readonly table: ITable;\n  /**\n   * table billing mode\n   *\n   * @default - best effort auto-detection or PROVISIONED as a fallback\n   */\n  readonly billingMode?: BillingMode;\n}\n\nexport class DynamoTableMetricFactory extends BaseMetricFactory<DynamoTableMetricFactoryProps> {\n  protected readonly table: ITable;\n\n  constructor(\n    metricFactory: MetricFactory,\n    props: DynamoTableMetricFactoryProps,\n  ) {\n    super(metricFactory, props);\n\n    this.table = props.table;\n  }\n\n  metricProvisionedReadCapacityUnits() {\n    return this.metricFactory.adaptMetric(\n      this.table.metric(\"ProvisionedReadCapacityUnits\", {\n        label: ProvisionedLabel,\n        statistic: MetricStatistic.AVERAGE,\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricProvisionedWriteCapacityUnits() {\n    return this.metricFactory.adaptMetric(\n      this.table.metric(\"ProvisionedWriteCapacityUnits\", {\n        label: ProvisionedLabel,\n        statistic: MetricStatistic.AVERAGE,\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricConsumedReadCapacityUnits() {\n    return this.metricFactory.createMetricMath(\n      \"consumed_rcu_sum/PERIOD(consumed_rcu_sum)\",\n      {\n        consumed_rcu_sum: this.table.metricConsumedReadCapacityUnits({\n          statistic: MetricStatistic.SUM,\n          region: this.region,\n          account: this.account,\n        }),\n      },\n      ConsumedLabel,\n      undefined,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricConsumedWriteCapacityUnits() {\n    return this.metricFactory.createMetricMath(\n      \"consumed_wcu_sum/PERIOD(consumed_wcu_sum)\",\n      {\n        consumed_wcu_sum: this.table.metricConsumedWriteCapacityUnits({\n          statistic: MetricStatistic.SUM,\n          region: this.region,\n          account: this.account,\n        }),\n      },\n      ConsumedLabel,\n      undefined,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricReadCapacityUtilizationPercentage() {\n    return this.metricFactory.createMetricMath(\n      \"100*(consumed_read_cap/provisioned_read_cap)\",\n      {\n        consumed_read_cap: this.metricConsumedReadCapacityUnits(),\n        provisioned_read_cap: this.metricProvisionedReadCapacityUnits(),\n      },\n      \"Utilization\",\n      undefined,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricWriteCapacityUtilizationPercentage() {\n    return this.metricFactory.createMetricMath(\n      \"100*(consumed_write_cap/provisioned_write_cap)\",\n      {\n        consumed_write_cap: this.metricConsumedWriteCapacityUnits(),\n        provisioned_write_cap: this.metricProvisionedWriteCapacityUnits(),\n      },\n      \"Utilization\",\n      undefined,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricSearchAverageSuccessfulRequestLatencyInMillis() {\n    // searches for all used operations\n    return this.metricFactory.createMetricSearch(\n      'MetricName=\"SuccessfulRequestLatency\"',\n      {\n        TableName: this.table.tableName,\n        Operation: undefined as unknown as string,\n      },\n      MetricStatistic.AVERAGE,\n      DynamoDbNamespace,\n      undefined,\n      undefined,\n      this.region,\n      this.account,\n    );\n  }\n\n  metricAverageSuccessfulRequestLatencyInMillis(operation: Operation) {\n    return this.metricFactory.adaptMetric(\n      this.table.metric(\"SuccessfulRequestLatency\", {\n        statistic: MetricStatistic.AVERAGE,\n        label: operation,\n        dimensionsMap: {\n          TableName: this.table.tableName,\n          Operation: operation,\n        },\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n\n  metricThrottledReadRequestCount() {\n    const readThrottles = this.metricFactory.adaptMetric(\n      this.table.metric(\"ReadThrottleEvents\", {\n        statistic: MetricStatistic.SUM,\n        label: ReadThrottleEventsLabel,\n        region: this.region,\n        account: this.account,\n      }),\n    );\n\n    return this.metricFactory.createMetricMath(\n      \"FILL(readThrottles,0)\",\n      { readThrottles },\n      ReadThrottleEventsLabel,\n    );\n  }\n\n  metricThrottledWriteRequestCount() {\n    const writeThrottles = this.metricFactory.adaptMetric(\n      this.table.metric(\"WriteThrottleEvents\", {\n        statistic: MetricStatistic.SUM,\n        label: WriteThrottleEventsLabel,\n        region: this.region,\n        account: this.account,\n      }),\n    );\n\n    return this.metricFactory.createMetricMath(\n      \"FILL(writeThrottles,0)\",\n      { writeThrottles },\n      WriteThrottleEventsLabel,\n    );\n  }\n\n  /**\n   * This represents the number of requests that resulted in a 500 (server error) error code.\n   * It summarizes across the basic CRUD operations:\n   * GetItem, BatchGetItem, Scan, Query, GetRecords, PutItem, DeleteItem, UpdateItem, BatchWriteItem\n   *\n   * It’s usually equal to zero.\n   */\n  metricSystemErrorsCount() {\n    const crudOperations = [\n      Operation.GET_ITEM,\n      Operation.BATCH_GET_ITEM,\n      Operation.SCAN,\n      Operation.QUERY,\n      Operation.GET_RECORDS,\n      Operation.PUT_ITEM,\n      Operation.DELETE_ITEM,\n      Operation.UPDATE_ITEM,\n      Operation.BATCH_WRITE_ITEM,\n    ];\n    const usingMetrics: Record<string, IMetric> = {};\n\n    crudOperations.forEach((operation) => {\n      const metric = this.table.metric(\"SystemErrors\", {\n        dimensionsMap: {\n          TableName: this.table.tableName,\n          Operation: operation,\n        },\n        statistic: MetricStatistic.SUM,\n        region: this.region,\n        account: this.account,\n      });\n\n      const metricId = \"systemError\" + operation;\n      usingMetrics[metricId] = this.metricFactory.adaptMetric(metric);\n    });\n\n    return this.metricFactory.createMetricMath(\n      // the metric is not emitted until error happens\n      Object.keys(usingMetrics).join(\"+\"),\n      usingMetrics,\n      \"System Errors\",\n    );\n  }\n\n  metricTimeToLiveDeletedItemCount() {\n    return this.metricFactory.adaptMetric(\n      this.table.metric(\"TimeToLiveDeletedItemCount\", {\n        label: \"TTL Deleted Item Count\",\n        statistic: MetricStatistic.MAX,\n        region: this.region,\n        account: this.account,\n      }),\n    );\n  }\n}\n"]}