UNPKG

cdk-monitoring-constructs

Version:

[![Gitpod Ready-to-Code](https://img.shields.io/badge/Gitpod-ready--to--code-blue?logo=gitpod)](https://gitpod.io/#https://github.com/cdklabs/cdk-monitoring-constructs) [![NPM version](https://badge.fury.io/js/cdk-monitoring-constructs.svg)](https://badge

91 lines 13.4 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.LambdaFunctionMetricFactory = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const common_1 = require("../../common"); class LambdaFunctionMetricFactory { constructor(metricFactory, props) { this.metricFactory = metricFactory; this.lambdaFunction = props.lambdaFunction; this.fillTpsWithZeroes = props.fillTpsWithZeroes ?? true; this.rateComputationMethod = props.rateComputationMethod ?? common_1.RateComputationMethod.AVERAGE; } /** * @deprecated use metricInvocationRate */ metricTps() { return this.metricFactory.toRate(this.metricInvocationCount(), common_1.RateComputationMethod.PER_SECOND, false, "requests", this.fillTpsWithZeroes); } metricInvocationRate() { return this.metricFactory.toRate(this.metricInvocationCount(), this.rateComputationMethod, false, "requests", this.fillTpsWithZeroes); } metricInvocationCount() { return this.metricFactory.adaptMetric(this.lambdaFunction.metricInvocations({ label: "Invocations", })); } metricThrottlesCount() { return this.metricFactory.adaptMetric(this.lambdaFunction.metricThrottles({ label: "Throttles", })); } metricThrottlesRate() { const metric = this.metricThrottlesCount(); return this.metricFactory.toRate(metric, this.rateComputationMethod, false, "throttles"); } metricFaultCount() { return this.metricFactory.adaptMetric(this.lambdaFunction.metricErrors({ label: "Faults", })); } metricFaultRate() { const metric = this.metricFaultCount(); return this.metricFactory.toRate(metric, this.rateComputationMethod, false, "faults"); } metricLatencyP99InMillis() { return this.metricFactory.adaptMetric(this.lambdaFunction.metricDuration({ statistic: common_1.MetricStatistic.P99, label: "P99", })); } metricLatencyP90InMillis() { return this.metricFactory.adaptMetric(this.lambdaFunction.metricDuration({ statistic: common_1.MetricStatistic.P90, label: "P90", })); } metricLatencyP50InMillis() { return this.metricFactory.adaptMetric(this.lambdaFunction.metricDuration({ statistic: common_1.MetricStatistic.P50, label: "P50", })); } metricConcurrentExecutions() { return this.metricFactory.adaptMetric(this.lambdaFunction.metric("ConcurrentExecutions", { statistic: common_1.MetricStatistic.MAX, label: "Concurrent", })); } metricProvisionedConcurrencySpilloverInvocations() { return this.metricFactory.adaptMetric(this.lambdaFunction.metric("ProvisionedConcurrencySpilloverInvocations", { statistic: common_1.MetricStatistic.SUM, label: "Provisioned Concurrency Spillovers", })); } metricProvisionedConcurrencySpilloverRate() { const metric = this.metricProvisionedConcurrencySpilloverInvocations(); return this.metricFactory.toRate(metric, this.rateComputationMethod, false, "pcsi"); } metricMaxIteratorAgeInMillis() { return this.metricFactory.adaptMetric(this.lambdaFunction.metric("IteratorAge", { statistic: common_1.MetricStatistic.MAX, label: "Iterator Age", })); } } exports.LambdaFunctionMetricFactory = LambdaFunctionMetricFactory; _a = JSII_RTTI_SYMBOL_1; LambdaFunctionMetricFactory[_a] = { fqn: "cdk-monitoring-constructs.LambdaFunctionMetricFactory", version: "1.21.0" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"LambdaFunctionMetricFactory.js","sourceRoot":"","sources":["LambdaFunctionMetricFactory.ts"],"names":[],"mappings":";;;;;AAEA,yCAIsB;AAuBtB,MAAa,2BAA2B;IAMtC,YACE,aAA4B,EAC5B,KAAuC;QAEvC,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;QACnC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;QAC3C,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,iBAAiB,IAAI,IAAI,CAAC;QACzD,IAAI,CAAC,qBAAqB;YACxB,KAAK,CAAC,qBAAqB,IAAI,8BAAqB,CAAC,OAAO,CAAC;IACjE,CAAC;IAED;;OAEG;IACH,SAAS;QACP,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAC9B,IAAI,CAAC,qBAAqB,EAAE,EAC5B,8BAAqB,CAAC,UAAU,EAChC,KAAK,EACL,UAAU,EACV,IAAI,CAAC,iBAAiB,CACvB,CAAC;IACJ,CAAC;IAED,oBAAoB;QAClB,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAC9B,IAAI,CAAC,qBAAqB,EAAE,EAC5B,IAAI,CAAC,qBAAqB,EAC1B,KAAK,EACL,UAAU,EACV,IAAI,CAAC,iBAAiB,CACvB,CAAC;IACJ,CAAC;IAED,qBAAqB;QACnB,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CACnC,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC;YACpC,KAAK,EAAE,aAAa;SACrB,CAAC,CACH,CAAC;IACJ,CAAC;IAED,oBAAoB;QAClB,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CACnC,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC;YAClC,KAAK,EAAE,WAAW;SACnB,CAAC,CACH,CAAC;IACJ,CAAC;IAED,mBAAmB;QACjB,MAAM,MAAM,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC3C,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAC9B,MAAM,EACN,IAAI,CAAC,qBAAqB,EAC1B,KAAK,EACL,WAAW,CACZ,CAAC;IACJ,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CACnC,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC;YAC/B,KAAK,EAAE,QAAQ;SAChB,CAAC,CACH,CAAC;IACJ,CAAC;IAED,eAAe;QACb,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACvC,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAC9B,MAAM,EACN,IAAI,CAAC,qBAAqB,EAC1B,KAAK,EACL,QAAQ,CACT,CAAC;IACJ,CAAC;IAED,wBAAwB;QACtB,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CACnC,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC;YACjC,SAAS,EAAE,wBAAe,CAAC,GAAG;YAC9B,KAAK,EAAE,KAAK;SACb,CAAC,CACH,CAAC;IACJ,CAAC;IAED,wBAAwB;QACtB,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CACnC,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC;YACjC,SAAS,EAAE,wBAAe,CAAC,GAAG;YAC9B,KAAK,EAAE,KAAK;SACb,CAAC,CACH,CAAC;IACJ,CAAC;IAED,wBAAwB;QACtB,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CACnC,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC;YACjC,SAAS,EAAE,wBAAe,CAAC,GAAG;YAC9B,KAAK,EAAE,KAAK;SACb,CAAC,CACH,CAAC;IACJ,CAAC;IAED,0BAA0B;QACxB,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CACnC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,sBAAsB,EAAE;YACjD,SAAS,EAAE,wBAAe,CAAC,GAAG;YAC9B,KAAK,EAAE,YAAY;SACpB,CAAC,CACH,CAAC;IACJ,CAAC;IAED,gDAAgD;QAC9C,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CACnC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,4CAA4C,EAAE;YACvE,SAAS,EAAE,wBAAe,CAAC,GAAG;YAC9B,KAAK,EAAE,oCAAoC;SAC5C,CAAC,CACH,CAAC;IACJ,CAAC;IAED,yCAAyC;QACvC,MAAM,MAAM,GAAG,IAAI,CAAC,gDAAgD,EAAE,CAAC;QACvE,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAC9B,MAAM,EACN,IAAI,CAAC,qBAAqB,EAC1B,KAAK,EACL,MAAM,CACP,CAAC;IACJ,CAAC;IAED,4BAA4B;QAC1B,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CACnC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,aAAa,EAAE;YACxC,SAAS,EAAE,wBAAe,CAAC,GAAG;YAC9B,KAAK,EAAE,cAAc;SACtB,CAAC,CACH,CAAC;IACJ,CAAC;;AAlJH,kEAmJC","sourcesContent":["import { IFunction } from \"aws-cdk-lib/aws-lambda\";\n\nimport {\n  MetricFactory,\n  MetricStatistic,\n  RateComputationMethod,\n} from \"../../common\";\n\nexport interface LambdaFunctionMetricFactoryProps {\n  readonly lambdaFunction: IFunction;\n  /**\n   * @default - true\n   */\n  readonly fillTpsWithZeroes?: boolean;\n  /**\n   * @default - average\n   */\n  readonly rateComputationMethod?: RateComputationMethod;\n  /**\n   * Generate dashboard charts for Lambda Insights metrics.\n   *\n   * To enable Lambda Insights on your Lambda function, see\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/Lambda-Insights-Getting-Started-clouddevelopmentkit.html\n   *\n   * @default - false\n   */\n  readonly lambdaInsightsEnabled?: boolean;\n}\n\nexport class LambdaFunctionMetricFactory {\n  protected readonly metricFactory: MetricFactory;\n  protected readonly lambdaFunction: IFunction;\n  protected readonly fillTpsWithZeroes: boolean;\n  protected readonly rateComputationMethod: RateComputationMethod;\n\n  constructor(\n    metricFactory: MetricFactory,\n    props: LambdaFunctionMetricFactoryProps\n  ) {\n    this.metricFactory = metricFactory;\n    this.lambdaFunction = props.lambdaFunction;\n    this.fillTpsWithZeroes = props.fillTpsWithZeroes ?? true;\n    this.rateComputationMethod =\n      props.rateComputationMethod ?? RateComputationMethod.AVERAGE;\n  }\n\n  /**\n   * @deprecated use metricInvocationRate\n   */\n  metricTps() {\n    return this.metricFactory.toRate(\n      this.metricInvocationCount(),\n      RateComputationMethod.PER_SECOND,\n      false,\n      \"requests\",\n      this.fillTpsWithZeroes\n    );\n  }\n\n  metricInvocationRate() {\n    return this.metricFactory.toRate(\n      this.metricInvocationCount(),\n      this.rateComputationMethod,\n      false,\n      \"requests\",\n      this.fillTpsWithZeroes\n    );\n  }\n\n  metricInvocationCount() {\n    return this.metricFactory.adaptMetric(\n      this.lambdaFunction.metricInvocations({\n        label: \"Invocations\",\n      })\n    );\n  }\n\n  metricThrottlesCount() {\n    return this.metricFactory.adaptMetric(\n      this.lambdaFunction.metricThrottles({\n        label: \"Throttles\",\n      })\n    );\n  }\n\n  metricThrottlesRate() {\n    const metric = this.metricThrottlesCount();\n    return this.metricFactory.toRate(\n      metric,\n      this.rateComputationMethod,\n      false,\n      \"throttles\"\n    );\n  }\n\n  metricFaultCount() {\n    return this.metricFactory.adaptMetric(\n      this.lambdaFunction.metricErrors({\n        label: \"Faults\",\n      })\n    );\n  }\n\n  metricFaultRate() {\n    const metric = this.metricFaultCount();\n    return this.metricFactory.toRate(\n      metric,\n      this.rateComputationMethod,\n      false,\n      \"faults\"\n    );\n  }\n\n  metricLatencyP99InMillis() {\n    return this.metricFactory.adaptMetric(\n      this.lambdaFunction.metricDuration({\n        statistic: MetricStatistic.P99,\n        label: \"P99\",\n      })\n    );\n  }\n\n  metricLatencyP90InMillis() {\n    return this.metricFactory.adaptMetric(\n      this.lambdaFunction.metricDuration({\n        statistic: MetricStatistic.P90,\n        label: \"P90\",\n      })\n    );\n  }\n\n  metricLatencyP50InMillis() {\n    return this.metricFactory.adaptMetric(\n      this.lambdaFunction.metricDuration({\n        statistic: MetricStatistic.P50,\n        label: \"P50\",\n      })\n    );\n  }\n\n  metricConcurrentExecutions() {\n    return this.metricFactory.adaptMetric(\n      this.lambdaFunction.metric(\"ConcurrentExecutions\", {\n        statistic: MetricStatistic.MAX,\n        label: \"Concurrent\",\n      })\n    );\n  }\n\n  metricProvisionedConcurrencySpilloverInvocations() {\n    return this.metricFactory.adaptMetric(\n      this.lambdaFunction.metric(\"ProvisionedConcurrencySpilloverInvocations\", {\n        statistic: MetricStatistic.SUM,\n        label: \"Provisioned Concurrency Spillovers\",\n      })\n    );\n  }\n\n  metricProvisionedConcurrencySpilloverRate() {\n    const metric = this.metricProvisionedConcurrencySpilloverInvocations();\n    return this.metricFactory.toRate(\n      metric,\n      this.rateComputationMethod,\n      false,\n      \"pcsi\"\n    );\n  }\n\n  metricMaxIteratorAgeInMillis() {\n    return this.metricFactory.adaptMetric(\n      this.lambdaFunction.metric(\"IteratorAge\", {\n        statistic: MetricStatistic.MAX,\n        label: \"Iterator Age\",\n      })\n    );\n  }\n}\n"]}