@liflig/cdk 3.24.1 → 3.24.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/slack-error-log-handler-lambda/__pycache__/index.cpython-314.pyc +0 -0
- package/assets/slack-error-log-handler-lambda/__pycache__/test_handler.cpython-314-pytest-9.0.3.pyc +0 -0
- package/lib/alarms/database-alarms.d.ts +12 -1
- package/lib/alarms/database-alarms.js +50 -47
- package/lib/rds/database.d.ts +11 -19
- package/lib/rds/database.js +7 -9
- package/package.json +2 -2
|
Binary file
|
package/assets/slack-error-log-handler-lambda/__pycache__/test_handler.cpython-314-pytest-9.0.3.pyc
CHANGED
|
Binary file
|
|
@@ -70,11 +70,17 @@ export declare class DatabaseAlarms extends constructs.Construct {
|
|
|
70
70
|
*/
|
|
71
71
|
addStorageSpaceAlarms(props?: {
|
|
72
72
|
/**
|
|
73
|
-
* Set to `false` to disable
|
|
73
|
+
* Set to `false` to disable all storage space alarms (both low and critically low).
|
|
74
|
+
* Individual alarms can still be disabled even when this is true.
|
|
74
75
|
* @default true
|
|
75
76
|
*/
|
|
76
77
|
enabled?: boolean;
|
|
77
78
|
lowStorageSpaceAlarm?: {
|
|
79
|
+
/**
|
|
80
|
+
* Set to `false` to disable the low storage space alarm.
|
|
81
|
+
* @default true
|
|
82
|
+
*/
|
|
83
|
+
enabled?: boolean;
|
|
78
84
|
/**
|
|
79
85
|
* An action to use for CloudWatch alarm state changes instead of the default action
|
|
80
86
|
*/
|
|
@@ -92,6 +98,11 @@ export declare class DatabaseAlarms extends constructs.Construct {
|
|
|
92
98
|
* Configuration for critically low storage alarm.
|
|
93
99
|
*/
|
|
94
100
|
criticallyLowStorageSpaceAlarm?: {
|
|
101
|
+
/**
|
|
102
|
+
* Set to `false` to disable the critically low storage space alarm.
|
|
103
|
+
* @default true
|
|
104
|
+
*/
|
|
105
|
+
enabled?: boolean;
|
|
95
106
|
/**
|
|
96
107
|
* An action to use for CloudWatch alarm state changes instead of the default action
|
|
97
108
|
*/
|
|
@@ -104,54 +104,57 @@ export class DatabaseAlarms extends constructs.Construct {
|
|
|
104
104
|
* categorized as a "warning", while the other one can be considered an "alarm".
|
|
105
105
|
*/
|
|
106
106
|
addStorageSpaceAlarms(props) {
|
|
107
|
-
// If
|
|
108
|
-
if (props?.enabled === false)
|
|
107
|
+
// If top-level enabled is explicitly false, skip all storage alarms
|
|
108
|
+
if (props?.enabled === false) {
|
|
109
109
|
return;
|
|
110
|
-
// Create Low Storage Space alarm
|
|
111
|
-
const lowStorageSpaceAlarm = new cloudwatch.Metric({
|
|
112
|
-
metricName: "FreeStorageSpace",
|
|
113
|
-
namespace: "AWS/RDS",
|
|
114
|
-
statistic: "Minimum",
|
|
115
|
-
period: cdk.Duration.minutes(5),
|
|
116
|
-
dimensionsMap: {
|
|
117
|
-
DBInstanceIdentifier: this.databaseInstanceIdentifier,
|
|
118
|
-
},
|
|
119
|
-
}).createAlarm(this, "LowStorageSpaceAlarm", {
|
|
120
|
-
alarmDescription: `Low storage space available on RDS database '${this.databaseInstanceIdentifier}'. ${props?.appendToAlarmDescription ?? ""}`,
|
|
121
|
-
comparisonOperator: cloudwatch.ComparisonOperator.LESS_THAN_THRESHOLD,
|
|
122
|
-
evaluationPeriods: 1,
|
|
123
|
-
threshold: props?.lowStorageSpaceAlarm?.threshold?.toBytes() ??
|
|
124
|
-
this.allocatedStorage.toBytes() * 0.25,
|
|
125
|
-
treatMissingData: cloudwatch.TreatMissingData.IGNORE,
|
|
126
|
-
});
|
|
127
|
-
// Default to the warning action
|
|
128
|
-
const lowAction = props?.lowStorageSpaceAlarm?.action ?? this.warningAction;
|
|
129
|
-
lowStorageSpaceAlarm.addAlarmAction(lowAction);
|
|
130
|
-
if (props?.lowStorageSpaceAlarm?.enableOkAlarm ?? true) {
|
|
131
|
-
lowStorageSpaceAlarm.addOkAction(lowAction);
|
|
132
110
|
}
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
111
|
+
if (props?.lowStorageSpaceAlarm?.enabled !== false) {
|
|
112
|
+
const lowStorageSpaceAlarm = new cloudwatch.Metric({
|
|
113
|
+
metricName: "FreeStorageSpace",
|
|
114
|
+
namespace: "AWS/RDS",
|
|
115
|
+
statistic: "Minimum",
|
|
116
|
+
period: cdk.Duration.minutes(5),
|
|
117
|
+
dimensionsMap: {
|
|
118
|
+
DBInstanceIdentifier: this.databaseInstanceIdentifier,
|
|
119
|
+
},
|
|
120
|
+
}).createAlarm(this, "LowStorageSpaceAlarm", {
|
|
121
|
+
alarmDescription: `Low storage space available on RDS database '${this.databaseInstanceIdentifier}'. ${props?.appendToAlarmDescription ?? ""}`,
|
|
122
|
+
comparisonOperator: cloudwatch.ComparisonOperator.LESS_THAN_THRESHOLD,
|
|
123
|
+
evaluationPeriods: 1,
|
|
124
|
+
threshold: props?.lowStorageSpaceAlarm?.threshold?.toBytes() ??
|
|
125
|
+
this.allocatedStorage.toBytes() * 0.25,
|
|
126
|
+
treatMissingData: cloudwatch.TreatMissingData.IGNORE,
|
|
127
|
+
});
|
|
128
|
+
// Default to the warning action
|
|
129
|
+
const lowAction = props?.lowStorageSpaceAlarm?.action ?? this.warningAction;
|
|
130
|
+
lowStorageSpaceAlarm.addAlarmAction(lowAction);
|
|
131
|
+
if (props?.lowStorageSpaceAlarm?.enableOkAlarm ?? true) {
|
|
132
|
+
lowStorageSpaceAlarm.addOkAction(lowAction);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
if (props?.criticallyLowStorageSpaceAlarm?.enabled !== false) {
|
|
136
|
+
const criticallyLowStorageSpaceAlarm = new cloudwatch.Metric({
|
|
137
|
+
metricName: "FreeStorageSpace",
|
|
138
|
+
namespace: "AWS/RDS",
|
|
139
|
+
statistic: "Minimum",
|
|
140
|
+
period: cdk.Duration.minutes(5),
|
|
141
|
+
dimensionsMap: {
|
|
142
|
+
DBInstanceIdentifier: this.databaseInstanceIdentifier,
|
|
143
|
+
},
|
|
144
|
+
}).createAlarm(this, "CriticallyLowStorageSpaceAlarm", {
|
|
145
|
+
alarmDescription: `Critically low storage space available on RDS database '${this.databaseInstanceIdentifier}'. ${props?.appendToAlarmDescription ?? ""}`,
|
|
146
|
+
comparisonOperator: cloudwatch.ComparisonOperator.LESS_THAN_THRESHOLD,
|
|
147
|
+
evaluationPeriods: 1,
|
|
148
|
+
threshold: props?.criticallyLowStorageSpaceAlarm?.threshold?.toBytes() ??
|
|
149
|
+
this.allocatedStorage.toBytes() * 0.05,
|
|
150
|
+
treatMissingData: cloudwatch.TreatMissingData.IGNORE,
|
|
151
|
+
});
|
|
152
|
+
// Default to the alarm action
|
|
153
|
+
const criticalAction = props?.criticallyLowStorageSpaceAlarm?.action ?? this.alarmAction;
|
|
154
|
+
criticallyLowStorageSpaceAlarm.addAlarmAction(criticalAction);
|
|
155
|
+
if (props?.criticallyLowStorageSpaceAlarm?.enableOkAlarm ?? true) {
|
|
156
|
+
criticallyLowStorageSpaceAlarm.addOkAction(criticalAction);
|
|
157
|
+
}
|
|
155
158
|
}
|
|
156
159
|
}
|
|
157
160
|
/**
|
|
@@ -188,4 +191,4 @@ export class DatabaseAlarms extends constructs.Construct {
|
|
|
188
191
|
}
|
|
189
192
|
}
|
|
190
193
|
}
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"database-alarms.js","sourceRoot":"","sources":["../../src/alarms/database-alarms.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from \"aws-cdk-lib\"\nimport * as cloudwatch from \"aws-cdk-lib/aws-cloudwatch\"\nimport type * as ec2 from \"aws-cdk-lib/aws-ec2\"\nimport * as constructs from \"constructs\"\n\nexport interface DatabaseAlarmsProps {\n  /**\n   * The action to use for alarms sent to \"alarms\" Slack channel,\n   * e.g., critical alerts.\n   */\n  alarmAction: cloudwatch.IAlarmAction\n  /**\n   * The action to use for alarms sent to \"warning\" Slack channel,\n   * e.g., less critical alerts.\n   */\n  warningAction: cloudwatch.IAlarmAction\n  instanceIdentifier: string\n  instanceType: ec2.InstanceType\n  allocatedStorage: cdk.Size\n}\n\n// Based on https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/burstable-credits-baseline-concepts.html#earning-CPU-credits\nconst cpuCreditBalanceByInstanceType: {\n  [instanceType: string]: number\n} = {\n  \"t2.nano\": 72,\n  \"t2.micro\": 144,\n  \"t2.small\": 288,\n  \"t2.medium\": 576,\n  \"t2.large\": 864,\n  \"t2.xlarge\": 1296,\n  \"t2.2xlarge\": 1958.4,\n  \"t3.nano\": 144,\n  \"t3.micro\": 288,\n  \"t3.small\": 576,\n  \"t3.medium\": 576,\n  \"t3.large\": 864,\n  \"t3.xlarge\": 2304,\n  \"t3.2xlarge\": 4608,\n  \"t3a.nano\": 144,\n  \"t3a.micro\": 288,\n  \"t3a.small\": 576,\n  \"t3a.medium\": 576,\n  \"t3a.large\": 864,\n  \"t3a.xlarge\": 2304,\n  \"t3a.2xlarge\": 4608,\n  \"t4g.nano\": 144,\n  \"t4g.micro\": 288,\n  \"t4g.small\": 576,\n  \"t4g.medium\": 576,\n  \"t4g.large\": 864,\n  \"t4g.xlarge\": 2304,\n  \"t4g.2xlarge\": 4608,\n}\n\nexport class DatabaseAlarms extends constructs.Construct {\n  private readonly alarmAction: cloudwatch.IAlarmAction\n  private readonly warningAction: cloudwatch.IAlarmAction\n  private readonly databaseInstanceIdentifier: string\n  private readonly instanceType: ec2.InstanceType\n  private readonly allocatedStorage: cdk.Size\n\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: DatabaseAlarmsProps,\n  ) {\n    super(scope, id)\n\n    this.alarmAction = props.alarmAction\n    this.warningAction = props.warningAction\n    this.databaseInstanceIdentifier = props.instanceIdentifier\n    this.instanceType = props.instanceType\n    this.allocatedStorage = props.allocatedStorage\n  }\n\n  /**\n   * Sets up a CloudWatch Alarm that triggers if the CPU credit balance for\n   * a burstable instance breach a certain threshold.\n   *\n   * NOTE: This alarm is only applicable for burstable instances, and a balance of 0 credits will only have performance\n   * implications for T2 instances. T3 and T4g instances will instead cost more for prolonged high CPU utilization after\n   * the balance is depleted.\n   */\n  addCpuCreditsAlarm(\n    /**\n     * Configuration for an alarm.\n     *\n     * @default Configured with sane defaults.\n     */\n    props?: {\n      /**\n       * An action to use for CloudWatch alarm state changes instead of the default action\n       */\n      action?: cloudwatch.IAlarmAction\n      /**\n       * The CloudWatch Alarm will change its state to ALARM if the number of CPU credits drops below this threshold.\n       *\n       * See https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/burstable-credits-baseline-concepts.html#earning-CPU-credits for an overview of maximum CPU credits for various instance types.\n       *\n       * @default 10% of the maximum earned CPU credits for the instance type.\n       */\n      threshold?: number\n      /**\n       * @default true\n       */\n      enableOkAlarm?: boolean\n      /**\n       * Add extra information to the alarm description, like Runbook URL or steps to triage.\n       */\n      appendToAlarmDescription?: string\n    },\n  ): void {\n    // CPU credits alarms are only applicable to burstable instance types.\n    // Explicitly throw if a caller tries to create this alarm for a\n    // non-burstable instance.\n    if (!this.instanceType.isBurstable()) {\n      throw new Error(\n        `addCpuCreditsAlarm: instance type '${this.instanceType.toString()}' is not burstable; this alarm is only applicable to burstable instance types.`,\n      )\n    }\n\n    const defaultThreshold =\n      cpuCreditBalanceByInstanceType[this.instanceType.toString()] * 0.1\n    const threshold = props?.threshold ?? defaultThreshold\n    if (!threshold) {\n      throw new Error(\n        `No threshold supplied, and unable to determine a default value for instance type '${this.instanceType.toString()}'`,\n      )\n    }\n    const creditsAlarm = new cloudwatch.Metric({\n      metricName: \"CPUCreditBalance\",\n      namespace: \"AWS/RDS\",\n      statistic: \"Minimum\",\n      period: cdk.Duration.minutes(5),\n      dimensionsMap: {\n        DBInstanceIdentifier: this.databaseInstanceIdentifier,\n      },\n    }).createAlarm(this, \"CreditsAlarm\", {\n      alarmDescription: `Less than ${threshold} CPU credits remaining for RDS database '${this.databaseInstanceIdentifier}'. ${\n        this.instanceType.toString().startsWith(\"t2.\")\n          ? \"If this reaches 0, the instance will be limited to a baseline CPU utilization.\"\n          : \"If the balance is depleted, AWS adds additional charges.\"\n      } ${props?.appendToAlarmDescription ?? \"\"}`,\n      comparisonOperator: cloudwatch.ComparisonOperator.LESS_THAN_THRESHOLD,\n      evaluationPeriods: 1,\n      threshold: threshold,\n      treatMissingData: cloudwatch.TreatMissingData.IGNORE,\n    })\n\n    // Default to the alarm action\n    creditsAlarm.addAlarmAction(props?.action ?? this.alarmAction)\n    if (props?.enableOkAlarm ?? true) {\n      creditsAlarm.addOkAction(props?.action ?? this.alarmAction)\n    }\n  }\n\n  /**\n   * Sets up two CloudWatch Alarms for monitoring disk storage space:\n   * 1) one that triggers if the available disk storage space is low.\n   * 2) one that triggers if the available disk storage space is critically low.\n   *\n   * You may want to use different alarm actions for the two alarms, e.g., one can be\n   * categorized as a \"warning\", while the other one can be considered an \"alarm\".\n   */\n  addStorageSpaceAlarms(props?: {\n    /**\n     * Set to `false` to disable both storage space alarms (low + critically low).\n     * @default true\n     */\n    enabled?: boolean\n    lowStorageSpaceAlarm?: {\n      /**\n       * An action to use for CloudWatch alarm state changes instead of the default action\n       */\n      action?: cloudwatch.IAlarmAction\n      /**\n       * @default 25% of the allocated storage.\n       */\n      threshold?: cdk.Size\n      /**\n       * Whether to attach OK actions for this alarm. @default true\n       */\n      enableOkAlarm?: boolean\n    }\n    /**\n     * Configuration for critically low storage alarm.\n     */\n    criticallyLowStorageSpaceAlarm?: {\n      /**\n       * An action to use for CloudWatch alarm state changes instead of the default action\n       */\n      action?: cloudwatch.IAlarmAction\n      /**\n       * @default 5% of the allocated storage.\n       */\n      threshold?: cdk.Size\n      /**\n       * Whether to attach OK actions for this alarm. @default true\n       */\n      enableOkAlarm?: boolean\n    }\n    /**\n     * Add extra information to the alarm description, like Runbook URL or steps to triage.\n     */\n    appendToAlarmDescription?: string\n  }): void {\n    // If the top-level enabled flag is explicitly false, do nothing\n    if (props?.enabled === false) return\n\n    // Create Low Storage Space alarm\n    const lowStorageSpaceAlarm = new cloudwatch.Metric({\n      metricName: \"FreeStorageSpace\",\n      namespace: \"AWS/RDS\",\n      statistic: \"Minimum\",\n      period: cdk.Duration.minutes(5),\n      dimensionsMap: {\n        DBInstanceIdentifier: this.databaseInstanceIdentifier,\n      },\n    }).createAlarm(this, \"LowStorageSpaceAlarm\", {\n      alarmDescription: `Low storage space available on RDS database '${this.databaseInstanceIdentifier}'. ${props?.appendToAlarmDescription ?? \"\"}`,\n      comparisonOperator: cloudwatch.ComparisonOperator.LESS_THAN_THRESHOLD,\n      evaluationPeriods: 1,\n      threshold:\n        props?.lowStorageSpaceAlarm?.threshold?.toBytes() ??\n        this.allocatedStorage.toBytes() * 0.25,\n      treatMissingData: cloudwatch.TreatMissingData.IGNORE,\n    })\n\n    // Default to the warning action\n    const lowAction = props?.lowStorageSpaceAlarm?.action ?? this.warningAction\n    lowStorageSpaceAlarm.addAlarmAction(lowAction)\n    if (props?.lowStorageSpaceAlarm?.enableOkAlarm ?? true) {\n      lowStorageSpaceAlarm.addOkAction(lowAction)\n    }\n\n    // Create Critically Low Storage Space alarm\n    const criticallyLowStorageSpaceAlarm = new cloudwatch.Metric({\n      metricName: \"FreeStorageSpace\",\n      namespace: \"AWS/RDS\",\n      statistic: \"Minimum\",\n      period: cdk.Duration.minutes(5),\n      dimensionsMap: {\n        DBInstanceIdentifier: this.databaseInstanceIdentifier,\n      },\n    }).createAlarm(this, \"CriticallyLowStorageSpaceAlarm\", {\n      alarmDescription: `Critically low storage space available on RDS database '${this.databaseInstanceIdentifier}'. ${props?.appendToAlarmDescription ?? \"\"}`,\n      comparisonOperator: cloudwatch.ComparisonOperator.LESS_THAN_THRESHOLD,\n      evaluationPeriods: 1,\n      threshold:\n        props?.criticallyLowStorageSpaceAlarm?.threshold?.toBytes() ??\n        this.allocatedStorage.toBytes() * 0.05,\n      treatMissingData: cloudwatch.TreatMissingData.IGNORE,\n    })\n\n    // Default to the alarm action\n    const criticalAction =\n      props?.criticallyLowStorageSpaceAlarm?.action ?? this.alarmAction\n    criticallyLowStorageSpaceAlarm.addAlarmAction(criticalAction)\n    if (props?.criticallyLowStorageSpaceAlarm?.enableOkAlarm ?? true) {\n      criticallyLowStorageSpaceAlarm.addOkAction(criticalAction)\n    }\n  }\n\n  /**\n   * Sets up a CloudWatch Alarm that triggers if the average CPU utilization for\n   * the RDS instance exceeds a given threshold.\n   */\n  addCpuUtilizationAlarm(\n    /**\n     * Configuration for an alarm.\n     *\n     * @default Configured with sane defaults.\n     */\n    props?: {\n      /**\n       * An action to use for CloudWatch alarm state changes instead of the default action\n       */\n      action?: cloudwatch.IAlarmAction\n      /**\n       * The threshold defined as a percentage that determines if CPU utilization should trigger an alarm or not.\n       * @default 80\n       */\n      threshold?: number\n      /**\n       * @default 5\n       */\n      evaluationPeriods?: number\n      /**\n       * @default 2 minutes\n       */\n      period?: cdk.Duration\n      /**\n       * Whether to attach OK actions for this alarm. @default true\n       */\n      enableOkAlarm?: boolean\n      /**\n       * Add extra information to the alarm description, like Runbook URL or steps to triage.\n       */\n      appendToAlarmDescription?: string\n    },\n  ): void {\n    const alarm = new cloudwatch.Metric({\n      metricName: \"CPUUtilization\",\n      namespace: \"AWS/RDS\",\n      statistic: \"Average\",\n      period: props?.period ?? cdk.Duration.minutes(2),\n      dimensionsMap: {\n        DBInstanceIdentifier: this.databaseInstanceIdentifier,\n      },\n    }).createAlarm(this, \"CpuUtilizationAlarm\", {\n      alarmDescription: `RDS database '${this.databaseInstanceIdentifier}' has a higher than expected CPU utilization. ${props?.appendToAlarmDescription ?? \"\"}`,\n      comparisonOperator: cloudwatch.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      evaluationPeriods: props?.evaluationPeriods ?? 5,\n      threshold: props?.threshold ?? 80,\n      treatMissingData: cloudwatch.TreatMissingData.IGNORE,\n    })\n    // Default to the warning action\n    const cpuAction = props?.action ?? this.warningAction\n    alarm.addAlarmAction(cpuAction)\n    if (props?.enableOkAlarm ?? true) {\n      alarm.addOkAction(cpuAction)\n    }\n  }\n}\n"]}
|
|
194
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"database-alarms.js","sourceRoot":"","sources":["../../src/alarms/database-alarms.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from \"aws-cdk-lib\"\nimport * as cloudwatch from \"aws-cdk-lib/aws-cloudwatch\"\nimport type * as ec2 from \"aws-cdk-lib/aws-ec2\"\nimport * as constructs from \"constructs\"\n\nexport interface DatabaseAlarmsProps {\n  /**\n   * The action to use for alarms sent to \"alarms\" Slack channel,\n   * e.g., critical alerts.\n   */\n  alarmAction: cloudwatch.IAlarmAction\n  /**\n   * The action to use for alarms sent to \"warning\" Slack channel,\n   * e.g., less critical alerts.\n   */\n  warningAction: cloudwatch.IAlarmAction\n  instanceIdentifier: string\n  instanceType: ec2.InstanceType\n  allocatedStorage: cdk.Size\n}\n\n// Based on https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/burstable-credits-baseline-concepts.html#earning-CPU-credits\nconst cpuCreditBalanceByInstanceType: {\n  [instanceType: string]: number\n} = {\n  \"t2.nano\": 72,\n  \"t2.micro\": 144,\n  \"t2.small\": 288,\n  \"t2.medium\": 576,\n  \"t2.large\": 864,\n  \"t2.xlarge\": 1296,\n  \"t2.2xlarge\": 1958.4,\n  \"t3.nano\": 144,\n  \"t3.micro\": 288,\n  \"t3.small\": 576,\n  \"t3.medium\": 576,\n  \"t3.large\": 864,\n  \"t3.xlarge\": 2304,\n  \"t3.2xlarge\": 4608,\n  \"t3a.nano\": 144,\n  \"t3a.micro\": 288,\n  \"t3a.small\": 576,\n  \"t3a.medium\": 576,\n  \"t3a.large\": 864,\n  \"t3a.xlarge\": 2304,\n  \"t3a.2xlarge\": 4608,\n  \"t4g.nano\": 144,\n  \"t4g.micro\": 288,\n  \"t4g.small\": 576,\n  \"t4g.medium\": 576,\n  \"t4g.large\": 864,\n  \"t4g.xlarge\": 2304,\n  \"t4g.2xlarge\": 4608,\n}\n\nexport class DatabaseAlarms extends constructs.Construct {\n  private readonly alarmAction: cloudwatch.IAlarmAction\n  private readonly warningAction: cloudwatch.IAlarmAction\n  private readonly databaseInstanceIdentifier: string\n  private readonly instanceType: ec2.InstanceType\n  private readonly allocatedStorage: cdk.Size\n\n  constructor(\n    scope: constructs.Construct,\n    id: string,\n    props: DatabaseAlarmsProps,\n  ) {\n    super(scope, id)\n\n    this.alarmAction = props.alarmAction\n    this.warningAction = props.warningAction\n    this.databaseInstanceIdentifier = props.instanceIdentifier\n    this.instanceType = props.instanceType\n    this.allocatedStorage = props.allocatedStorage\n  }\n\n  /**\n   * Sets up a CloudWatch Alarm that triggers if the CPU credit balance for\n   * a burstable instance breach a certain threshold.\n   *\n   * NOTE: This alarm is only applicable for burstable instances, and a balance of 0 credits will only have performance\n   * implications for T2 instances. T3 and T4g instances will instead cost more for prolonged high CPU utilization after\n   * the balance is depleted.\n   */\n  addCpuCreditsAlarm(\n    /**\n     * Configuration for an alarm.\n     *\n     * @default Configured with sane defaults.\n     */\n    props?: {\n      /**\n       * An action to use for CloudWatch alarm state changes instead of the default action\n       */\n      action?: cloudwatch.IAlarmAction\n      /**\n       * The CloudWatch Alarm will change its state to ALARM if the number of CPU credits drops below this threshold.\n       *\n       * See https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/burstable-credits-baseline-concepts.html#earning-CPU-credits for an overview of maximum CPU credits for various instance types.\n       *\n       * @default 10% of the maximum earned CPU credits for the instance type.\n       */\n      threshold?: number\n      /**\n       * @default true\n       */\n      enableOkAlarm?: boolean\n      /**\n       * Add extra information to the alarm description, like Runbook URL or steps to triage.\n       */\n      appendToAlarmDescription?: string\n    },\n  ): void {\n    // CPU credits alarms are only applicable to burstable instance types.\n    // Explicitly throw if a caller tries to create this alarm for a\n    // non-burstable instance.\n    if (!this.instanceType.isBurstable()) {\n      throw new Error(\n        `addCpuCreditsAlarm: instance type '${this.instanceType.toString()}' is not burstable; this alarm is only applicable to burstable instance types.`,\n      )\n    }\n\n    const defaultThreshold =\n      cpuCreditBalanceByInstanceType[this.instanceType.toString()] * 0.1\n    const threshold = props?.threshold ?? defaultThreshold\n    if (!threshold) {\n      throw new Error(\n        `No threshold supplied, and unable to determine a default value for instance type '${this.instanceType.toString()}'`,\n      )\n    }\n    const creditsAlarm = new cloudwatch.Metric({\n      metricName: \"CPUCreditBalance\",\n      namespace: \"AWS/RDS\",\n      statistic: \"Minimum\",\n      period: cdk.Duration.minutes(5),\n      dimensionsMap: {\n        DBInstanceIdentifier: this.databaseInstanceIdentifier,\n      },\n    }).createAlarm(this, \"CreditsAlarm\", {\n      alarmDescription: `Less than ${threshold} CPU credits remaining for RDS database '${this.databaseInstanceIdentifier}'. ${\n        this.instanceType.toString().startsWith(\"t2.\")\n          ? \"If this reaches 0, the instance will be limited to a baseline CPU utilization.\"\n          : \"If the balance is depleted, AWS adds additional charges.\"\n      } ${props?.appendToAlarmDescription ?? \"\"}`,\n      comparisonOperator: cloudwatch.ComparisonOperator.LESS_THAN_THRESHOLD,\n      evaluationPeriods: 1,\n      threshold: threshold,\n      treatMissingData: cloudwatch.TreatMissingData.IGNORE,\n    })\n\n    // Default to the alarm action\n    creditsAlarm.addAlarmAction(props?.action ?? this.alarmAction)\n    if (props?.enableOkAlarm ?? true) {\n      creditsAlarm.addOkAction(props?.action ?? this.alarmAction)\n    }\n  }\n\n  /**\n   * Sets up two CloudWatch Alarms for monitoring disk storage space:\n   * 1) one that triggers if the available disk storage space is low.\n   * 2) one that triggers if the available disk storage space is critically low.\n   *\n   * You may want to use different alarm actions for the two alarms, e.g., one can be\n   * categorized as a \"warning\", while the other one can be considered an \"alarm\".\n   */\n  addStorageSpaceAlarms(props?: {\n    /**\n     * Set to `false` to disable all storage space alarms (both low and critically low).\n     * Individual alarms can still be disabled even when this is true.\n     * @default true\n     */\n    enabled?: boolean\n    lowStorageSpaceAlarm?: {\n      /**\n       * Set to `false` to disable the low storage space alarm.\n       * @default true\n       */\n      enabled?: boolean\n      /**\n       * An action to use for CloudWatch alarm state changes instead of the default action\n       */\n      action?: cloudwatch.IAlarmAction\n      /**\n       * @default 25% of the allocated storage.\n       */\n      threshold?: cdk.Size\n      /**\n       * Whether to attach OK actions for this alarm. @default true\n       */\n      enableOkAlarm?: boolean\n    }\n    /**\n     * Configuration for critically low storage alarm.\n     */\n    criticallyLowStorageSpaceAlarm?: {\n      /**\n       * Set to `false` to disable the critically low storage space alarm.\n       * @default true\n       */\n      enabled?: boolean\n      /**\n       * An action to use for CloudWatch alarm state changes instead of the default action\n       */\n      action?: cloudwatch.IAlarmAction\n      /**\n       * @default 5% of the allocated storage.\n       */\n      threshold?: cdk.Size\n      /**\n       * Whether to attach OK actions for this alarm. @default true\n       */\n      enableOkAlarm?: boolean\n    }\n    /**\n     * Add extra information to the alarm description, like Runbook URL or steps to triage.\n     */\n    appendToAlarmDescription?: string\n  }): void {\n    // If top-level enabled is explicitly false, skip all storage alarms\n    if (props?.enabled === false) {\n      return\n    }\n    if (props?.lowStorageSpaceAlarm?.enabled !== false) {\n      const lowStorageSpaceAlarm = new cloudwatch.Metric({\n        metricName: \"FreeStorageSpace\",\n        namespace: \"AWS/RDS\",\n        statistic: \"Minimum\",\n        period: cdk.Duration.minutes(5),\n        dimensionsMap: {\n          DBInstanceIdentifier: this.databaseInstanceIdentifier,\n        },\n      }).createAlarm(this, \"LowStorageSpaceAlarm\", {\n        alarmDescription: `Low storage space available on RDS database '${this.databaseInstanceIdentifier}'. ${props?.appendToAlarmDescription ?? \"\"}`,\n        comparisonOperator: cloudwatch.ComparisonOperator.LESS_THAN_THRESHOLD,\n        evaluationPeriods: 1,\n        threshold:\n          props?.lowStorageSpaceAlarm?.threshold?.toBytes() ??\n          this.allocatedStorage.toBytes() * 0.25,\n        treatMissingData: cloudwatch.TreatMissingData.IGNORE,\n      })\n\n      // Default to the warning action\n      const lowAction =\n        props?.lowStorageSpaceAlarm?.action ?? this.warningAction\n      lowStorageSpaceAlarm.addAlarmAction(lowAction)\n      if (props?.lowStorageSpaceAlarm?.enableOkAlarm ?? true) {\n        lowStorageSpaceAlarm.addOkAction(lowAction)\n      }\n    }\n    if (props?.criticallyLowStorageSpaceAlarm?.enabled !== false) {\n      const criticallyLowStorageSpaceAlarm = new cloudwatch.Metric({\n        metricName: \"FreeStorageSpace\",\n        namespace: \"AWS/RDS\",\n        statistic: \"Minimum\",\n        period: cdk.Duration.minutes(5),\n        dimensionsMap: {\n          DBInstanceIdentifier: this.databaseInstanceIdentifier,\n        },\n      }).createAlarm(this, \"CriticallyLowStorageSpaceAlarm\", {\n        alarmDescription: `Critically low storage space available on RDS database '${this.databaseInstanceIdentifier}'. ${props?.appendToAlarmDescription ?? \"\"}`,\n        comparisonOperator: cloudwatch.ComparisonOperator.LESS_THAN_THRESHOLD,\n        evaluationPeriods: 1,\n        threshold:\n          props?.criticallyLowStorageSpaceAlarm?.threshold?.toBytes() ??\n          this.allocatedStorage.toBytes() * 0.05,\n        treatMissingData: cloudwatch.TreatMissingData.IGNORE,\n      })\n\n      // Default to the alarm action\n      const criticalAction =\n        props?.criticallyLowStorageSpaceAlarm?.action ?? this.alarmAction\n      criticallyLowStorageSpaceAlarm.addAlarmAction(criticalAction)\n      if (props?.criticallyLowStorageSpaceAlarm?.enableOkAlarm ?? true) {\n        criticallyLowStorageSpaceAlarm.addOkAction(criticalAction)\n      }\n    }\n  }\n\n  /**\n   * Sets up a CloudWatch Alarm that triggers if the average CPU utilization for\n   * the RDS instance exceeds a given threshold.\n   */\n  addCpuUtilizationAlarm(\n    /**\n     * Configuration for an alarm.\n     *\n     * @default Configured with sane defaults.\n     */\n    props?: {\n      /**\n       * An action to use for CloudWatch alarm state changes instead of the default action\n       */\n      action?: cloudwatch.IAlarmAction\n      /**\n       * The threshold defined as a percentage that determines if CPU utilization should trigger an alarm or not.\n       * @default 80\n       */\n      threshold?: number\n      /**\n       * @default 5\n       */\n      evaluationPeriods?: number\n      /**\n       * @default 2 minutes\n       */\n      period?: cdk.Duration\n      /**\n       * Whether to attach OK actions for this alarm. @default true\n       */\n      enableOkAlarm?: boolean\n      /**\n       * Add extra information to the alarm description, like Runbook URL or steps to triage.\n       */\n      appendToAlarmDescription?: string\n    },\n  ): void {\n    const alarm = new cloudwatch.Metric({\n      metricName: \"CPUUtilization\",\n      namespace: \"AWS/RDS\",\n      statistic: \"Average\",\n      period: props?.period ?? cdk.Duration.minutes(2),\n      dimensionsMap: {\n        DBInstanceIdentifier: this.databaseInstanceIdentifier,\n      },\n    }).createAlarm(this, \"CpuUtilizationAlarm\", {\n      alarmDescription: `RDS database '${this.databaseInstanceIdentifier}' has a higher than expected CPU utilization. ${props?.appendToAlarmDescription ?? \"\"}`,\n      comparisonOperator: cloudwatch.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      evaluationPeriods: props?.evaluationPeriods ?? 5,\n      threshold: props?.threshold ?? 80,\n      treatMissingData: cloudwatch.TreatMissingData.IGNORE,\n    })\n    // Default to the warning action\n    const cpuAction = props?.action ?? this.warningAction\n    alarm.addAlarmAction(cpuAction)\n    if (props?.enableOkAlarm ?? true) {\n      alarm.addOkAction(cpuAction)\n    }\n  }\n}\n"]}
|
package/lib/rds/database.d.ts
CHANGED
|
@@ -40,10 +40,16 @@ export type DatabaseAlarmsConfig = {
|
|
|
40
40
|
storageSpaceAlarms?: {
|
|
41
41
|
/**
|
|
42
42
|
* Set to `false` to disable all storage space alarms (both low and critically low).
|
|
43
|
+
* Individual alarms can still be disabled even when this is true.
|
|
43
44
|
* @default true
|
|
44
45
|
*/
|
|
45
46
|
enabled?: boolean;
|
|
46
47
|
lowStorageSpaceAlarm?: {
|
|
48
|
+
/**
|
|
49
|
+
* Set to `false` to disable the low storage space alarm.
|
|
50
|
+
* @default true
|
|
51
|
+
*/
|
|
52
|
+
enabled?: boolean;
|
|
47
53
|
action?: cloudwatch.IAlarmAction;
|
|
48
54
|
/** Whether to attach OK actions for this alarm. @default true */
|
|
49
55
|
enableOkAlarm?: boolean;
|
|
@@ -51,6 +57,11 @@ export type DatabaseAlarmsConfig = {
|
|
|
51
57
|
threshold?: cdk.Size;
|
|
52
58
|
};
|
|
53
59
|
criticallyLowStorageSpaceAlarm?: {
|
|
60
|
+
/**
|
|
61
|
+
* Set to `false` to disable the critically low storage space alarm.
|
|
62
|
+
* @default true
|
|
63
|
+
*/
|
|
64
|
+
enabled?: boolean;
|
|
54
65
|
action?: cloudwatch.IAlarmAction;
|
|
55
66
|
/** Whether to attach OK actions for this alarm. @default true */
|
|
56
67
|
enableOkAlarm?: boolean;
|
|
@@ -109,25 +120,6 @@ export interface DatabaseProps extends cdk.StackProps {
|
|
|
109
120
|
* @default false
|
|
110
121
|
*/
|
|
111
122
|
usePublicSubnets?: boolean;
|
|
112
|
-
/**
|
|
113
|
-
* Whether to enable automatic minor version upgrades for the database engine.
|
|
114
|
-
*
|
|
115
|
-
* Note: enabling this means the actual database version may drift from
|
|
116
|
-
* what is specified in the IaC, as AWS applies upgrades outside of deployments.
|
|
117
|
-
*
|
|
118
|
-
* When enabled, consider also setting `preferredMaintenanceWindow`
|
|
119
|
-
* to control when upgrades are applied.
|
|
120
|
-
*
|
|
121
|
-
* @default false
|
|
122
|
-
*/
|
|
123
|
-
autoMinorVersionUpgrade?: boolean;
|
|
124
|
-
/**
|
|
125
|
-
* Weekly time range during which system maintenance can occur,
|
|
126
|
-
* in UTC (e.g. "sun:03:00-sun:04:00").
|
|
127
|
-
*
|
|
128
|
-
* If not specified, AWS will choose a default window.
|
|
129
|
-
*/
|
|
130
|
-
preferredMaintenanceWindow?: string;
|
|
131
123
|
overrideDbOptions?: Partial<rds.DatabaseInstanceSourceProps>;
|
|
132
124
|
/**
|
|
133
125
|
* Configure database alarms.
|
package/lib/rds/database.js
CHANGED
|
@@ -27,8 +27,6 @@ export class Database extends constructs.Construct {
|
|
|
27
27
|
subnetType: ec2.SubnetType.PUBLIC,
|
|
28
28
|
}
|
|
29
29
|
: undefined,
|
|
30
|
-
autoMinorVersionUpgrade: props.autoMinorVersionUpgrade ?? false,
|
|
31
|
-
preferredMaintenanceWindow: props.preferredMaintenanceWindow,
|
|
32
30
|
multiAz: props.isMultiAz ?? true,
|
|
33
31
|
// We default to 25 GiB storage instead of 100 GiB
|
|
34
32
|
// if we do not specify.
|
|
@@ -39,10 +37,6 @@ export class Database extends constructs.Construct {
|
|
|
39
37
|
};
|
|
40
38
|
this.allocatedStorage = cdk.Size.gibibytes(options.allocatedStorage);
|
|
41
39
|
this.instanceType = options.instanceType;
|
|
42
|
-
if (options.autoMinorVersionUpgrade &&
|
|
43
|
-
!options.preferredMaintenanceWindow) {
|
|
44
|
-
cdk.Annotations.of(this).addWarningV2("@liflig/cdk:autoMinorVersionUpgradeWithoutMaintenanceWindow", "Auto minor version upgrade is enabled but no maintenance window is specified. AWS will choose a default maintenance window which may not suit your availability requirements.");
|
|
45
|
-
}
|
|
46
40
|
const db = props.snapshotIdentifier
|
|
47
41
|
? new rds.DatabaseInstanceFromSnapshot(this, "Resource", {
|
|
48
42
|
...options,
|
|
@@ -83,10 +77,14 @@ export class Database extends constructs.Construct {
|
|
|
83
77
|
appendToAlarmDescription: alarms.cpuCreditsAlarm?.appendToAlarmDescription,
|
|
84
78
|
});
|
|
85
79
|
}
|
|
86
|
-
if (alarms.storageSpaceAlarms
|
|
80
|
+
if (alarms.storageSpaceAlarms) {
|
|
87
81
|
dbAlarms.addStorageSpaceAlarms({
|
|
88
|
-
|
|
82
|
+
enabled: alarms.storageSpaceAlarms.enabled,
|
|
83
|
+
lowStorageSpaceAlarm: alarms.storageSpaceAlarms.lowStorageSpaceAlarm,
|
|
84
|
+
criticallyLowStorageSpaceAlarm: alarms.storageSpaceAlarms.criticallyLowStorageSpaceAlarm,
|
|
85
|
+
appendToAlarmDescription: alarms.storageSpaceAlarms.appendToAlarmDescription,
|
|
89
86
|
});
|
|
87
|
+
}
|
|
90
88
|
if (alarms.cpuUtilizationAlarm?.enabled !== false) {
|
|
91
89
|
dbAlarms.addCpuUtilizationAlarm({
|
|
92
90
|
action: alarms.cpuUtilizationAlarm?.action,
|
|
@@ -103,4 +101,4 @@ export class Database extends constructs.Construct {
|
|
|
103
101
|
this.connections.allowDefaultPortFrom(source);
|
|
104
102
|
}
|
|
105
103
|
}
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"database.js","sourceRoot":"","sources":["../../src/rds/database.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from \"aws-cdk-lib\"\nimport type * as cloudwatch from \"aws-cdk-lib/aws-cloudwatch\"\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\"\nimport * as rds from \"aws-cdk-lib/aws-rds\"\nimport type * as sm from \"aws-cdk-lib/aws-secretsmanager\"\nimport * as constructs from \"constructs\"\nimport { DatabaseAlarms } from \"../alarms\"\n\n/**\n * Configure database alarms.\n *\n * Alarms are enabled by default (when you supply an `alarmAction` and\n * `warningAction`). To explicitly disable automatic alarms use\n * `{ enabled: false }`.\n */\nexport type DatabaseAlarmsConfig =\n  | { enabled: false }\n  | {\n      /**\n       * When alarms are enabled, both actions are required.\n       */\n      alarmAction: cloudwatch.IAlarmAction\n      warningAction: cloudwatch.IAlarmAction\n\n      /**\n       * CPU credits alarm config\n       */\n      cpuCreditsAlarm?: {\n        /**\n         * @default true if instance type is burstable\n         */\n        enabled?: boolean\n        /** Whether to attach OK actions for this alarm. @default true */\n        enableOkAlarm?: boolean\n        action?: cloudwatch.IAlarmAction\n        /** @default 10% of maximum earned credits for instance type */\n        threshold?: number\n        appendToAlarmDescription?: string\n      }\n\n      /**\n       * Storage space alarm overrides\n       */\n      storageSpaceAlarms?: {\n        /**\n         * Set to `false` to disable all storage space alarms (both low and critically low).\n         * @default true\n         */\n        enabled?: boolean\n        lowStorageSpaceAlarm?: {\n          action?: cloudwatch.IAlarmAction\n          /** Whether to attach OK actions for this alarm. @default true */\n          enableOkAlarm?: boolean\n          /** @default 25% of allocated storage */\n          threshold?: cdk.Size\n        }\n        criticallyLowStorageSpaceAlarm?: {\n          action?: cloudwatch.IAlarmAction\n          /** Whether to attach OK actions for this alarm. @default true */\n          enableOkAlarm?: boolean\n          /** @default 5% of allocated storage */\n          threshold?: cdk.Size\n        }\n        appendToAlarmDescription?: string\n      }\n\n      /**\n       * CPU utilization alarm overrides.\n       */\n      cpuUtilizationAlarm?: {\n        enabled?: boolean\n        /** Whether to attach OK actions for this alarm. @default true */\n        enableOkAlarm?: boolean\n        action?: cloudwatch.IAlarmAction\n        /** @default 80 */\n        threshold?: number\n        /** @default 5 */\n        evaluationPeriods?: number\n        /** @default 2 minutes */\n        period?: cdk.Duration\n        appendToAlarmDescription?: string\n      }\n    }\n\nexport interface DatabaseProps extends cdk.StackProps {\n  vpc: ec2.IVpc\n  engine: rds.IInstanceEngine\n  /**\n   * @default master\n   */\n  masterUsername?: string\n  /**\n   * @default app\n   */\n  databaseName?: string\n  /**\n   * @default 25\n   */\n  allocatedStorageGb?: number\n  instanceType: ec2.InstanceType\n  instanceIdentifier: string\n  /**\n   * @default true\n   */\n  isMultiAz?: boolean\n  /**\n   * Must not be removed once it has been set, as changing this\n   * results in a new DB instance being created.\n   *\n   * Also, remember to give database a new name when changing this prop, or else\n   * the new instance name will crash with the existing instance.\n   */\n  snapshotIdentifier?: string\n  /**\n   * @default false\n   */\n  usePublicSubnets?: boolean\n  /**\n   * Whether to enable automatic minor version upgrades for the database engine.\n   *\n   * Note: enabling this means the actual database version may drift from\n   * what is specified in the IaC, as AWS applies upgrades outside of deployments.\n   *\n   * When enabled, consider also setting `preferredMaintenanceWindow`\n   * to control when upgrades are applied.\n   *\n   * @default false\n   */\n  autoMinorVersionUpgrade?: boolean\n  /**\n   * Weekly time range during which system maintenance can occur,\n   * in UTC (e.g. \"sun:03:00-sun:04:00\").\n   *\n   * If not specified, AWS will choose a default window.\n   */\n  preferredMaintenanceWindow?: string\n  overrideDbOptions?: Partial<rds.DatabaseInstanceSourceProps>\n  /**\n   * Configure database alarms.\n   *\n   * This property is required and must be one of two shapes:\n   *  - `{ enabled: false }` to explicitly disable automatic alarms\n   *  - `{ alarmAction, warningAction }` to enable alarms and provide both channels\n   *\n   * Default: enabled.\n   */\n  alarms: DatabaseAlarmsConfig\n}\n\nexport class Database extends constructs.Construct {\n  public readonly secret: sm.ISecret\n  public readonly connections: ec2.Connections\n  public readonly databaseInstance: rds.IDatabaseInstance\n  public readonly instanceType: ec2.InstanceType\n  public readonly allocatedStorage: cdk.Size\n\n  constructor(scope: constructs.Construct, id: string, props: DatabaseProps) {\n    super(scope, id)\n\n    const masterUsername = props.masterUsername ?? \"master\"\n    const databaseName = props.databaseName ?? \"app\"\n\n    const secret = new rds.DatabaseSecret(this, \"Secret\", {\n      username: masterUsername,\n    })\n\n    const options: rds.DatabaseInstanceSourceProps = {\n      engine: props.engine,\n      allowMajorVersionUpgrade: true,\n      instanceIdentifier: props.instanceIdentifier,\n      instanceType: props.instanceType,\n      vpc: props.vpc,\n      vpcSubnets: props.usePublicSubnets\n        ? {\n            subnetType: ec2.SubnetType.PUBLIC,\n          }\n        : undefined,\n      autoMinorVersionUpgrade: props.autoMinorVersionUpgrade ?? false,\n      preferredMaintenanceWindow: props.preferredMaintenanceWindow,\n      multiAz: props.isMultiAz ?? true,\n      // We default to 25 GiB storage instead of 100 GiB\n      // if we do not specify.\n      allocatedStorage: props.allocatedStorageGb ?? 25,\n      // We specify maximum backup retention.\n      backupRetention: cdk.Duration.days(35),\n      ...props.overrideDbOptions,\n    }\n    this.allocatedStorage = cdk.Size.gibibytes(options.allocatedStorage!)\n    this.instanceType = options.instanceType!\n\n    if (\n      options.autoMinorVersionUpgrade &&\n      !options.preferredMaintenanceWindow\n    ) {\n      cdk.Annotations.of(this).addWarningV2(\n        \"@liflig/cdk:autoMinorVersionUpgradeWithoutMaintenanceWindow\",\n        \"Auto minor version upgrade is enabled but no maintenance window is specified. AWS will choose a default maintenance window which may not suit your availability requirements.\",\n      )\n    }\n\n    const db = props.snapshotIdentifier\n      ? new rds.DatabaseInstanceFromSnapshot(this, \"Resource\", {\n          ...options,\n          snapshotIdentifier: props.snapshotIdentifier,\n          credentials: rds.SnapshotCredentials.fromSecret(secret),\n        })\n      : new rds.DatabaseInstance(this, \"Resource\", {\n          ...options,\n          databaseName,\n          credentials: rds.Credentials.fromSecret(secret),\n          storageEncrypted: true,\n        })\n\n    this.databaseInstance = db\n\n    this.secret = db.secret!\n    this.connections = db.connections\n\n    // Override in case we have placed it in a public subnet.\n    // It would default to being public accessible which we do not want.\n    ;(db.node.defaultChild as rds.CfnDBInstance).publiclyAccessible = false\n\n    if (\"alarmAction\" in props.alarms) {\n      const alarms = props.alarms\n\n      const dbAlarms = new DatabaseAlarms(this, \"Alarms\", {\n        instanceIdentifier: props.instanceIdentifier,\n        instanceType: props.instanceType,\n        allocatedStorage: cdk.Size.gibibytes(options.allocatedStorage!),\n        alarmAction: alarms.alarmAction,\n        warningAction: alarms.warningAction,\n      })\n\n      // Default mapping:\n      // - low CPU credits -> alarm\n      // - critically low storage -> alarm\n      // - low storage -> warning\n      // - high CPU utilization -> warning\n      // Only create the CPU credits alarm if the instance type is burstable.\n      if (\n        this.instanceType.isBurstable() &&\n        alarms.cpuCreditsAlarm?.enabled !== false\n      ) {\n        dbAlarms.addCpuCreditsAlarm({\n          action: alarms.cpuCreditsAlarm?.action,\n          threshold: alarms.cpuCreditsAlarm?.threshold,\n          enableOkAlarm: alarms.cpuCreditsAlarm?.enableOkAlarm,\n          appendToAlarmDescription:\n            alarms.cpuCreditsAlarm?.appendToAlarmDescription,\n        })\n      }\n\n      if (alarms.storageSpaceAlarms?.enabled !== false)\n        dbAlarms.addStorageSpaceAlarms({\n          ...alarms.storageSpaceAlarms,\n        })\n\n      if (alarms.cpuUtilizationAlarm?.enabled !== false) {\n        dbAlarms.addCpuUtilizationAlarm({\n          action: alarms.cpuUtilizationAlarm?.action,\n          threshold: alarms.cpuUtilizationAlarm?.threshold,\n          evaluationPeriods: alarms.cpuUtilizationAlarm?.evaluationPeriods,\n          period: alarms.cpuUtilizationAlarm?.period,\n          enableOkAlarm: alarms.cpuUtilizationAlarm?.enableOkAlarm,\n          appendToAlarmDescription:\n            alarms.cpuUtilizationAlarm?.appendToAlarmDescription,\n        })\n      }\n    }\n  }\n\n  public allowConnectionFrom(source: ec2.ISecurityGroup): void {\n    this.connections.allowDefaultPortFrom(source)\n  }\n}\n"]}
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"database.js","sourceRoot":"","sources":["../../src/rds/database.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from \"aws-cdk-lib\"\nimport type * as cloudwatch from \"aws-cdk-lib/aws-cloudwatch\"\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\"\nimport * as rds from \"aws-cdk-lib/aws-rds\"\nimport type * as sm from \"aws-cdk-lib/aws-secretsmanager\"\nimport * as constructs from \"constructs\"\nimport { DatabaseAlarms } from \"../alarms\"\n\n/**\n * Configure database alarms.\n *\n * Alarms are enabled by default (when you supply an `alarmAction` and\n * `warningAction`). To explicitly disable automatic alarms use\n * `{ enabled: false }`.\n */\nexport type DatabaseAlarmsConfig =\n  | { enabled: false }\n  | {\n      /**\n       * When alarms are enabled, both actions are required.\n       */\n      alarmAction: cloudwatch.IAlarmAction\n      warningAction: cloudwatch.IAlarmAction\n\n      /**\n       * CPU credits alarm config\n       */\n      cpuCreditsAlarm?: {\n        /**\n         * @default true if instance type is burstable\n         */\n        enabled?: boolean\n        /** Whether to attach OK actions for this alarm. @default true */\n        enableOkAlarm?: boolean\n        action?: cloudwatch.IAlarmAction\n        /** @default 10% of maximum earned credits for instance type */\n        threshold?: number\n        appendToAlarmDescription?: string\n      }\n\n      /**\n       * Storage space alarm overrides\n       */\n      storageSpaceAlarms?: {\n        /**\n         * Set to `false` to disable all storage space alarms (both low and critically low).\n         * Individual alarms can still be disabled even when this is true.\n         * @default true\n         */\n        enabled?: boolean\n        lowStorageSpaceAlarm?: {\n          /**\n           * Set to `false` to disable the low storage space alarm.\n           * @default true\n           */\n          enabled?: boolean\n          action?: cloudwatch.IAlarmAction\n          /** Whether to attach OK actions for this alarm. @default true */\n          enableOkAlarm?: boolean\n          /** @default 25% of allocated storage */\n          threshold?: cdk.Size\n        }\n        criticallyLowStorageSpaceAlarm?: {\n          /**\n           * Set to `false` to disable the critically low storage space alarm.\n           * @default true\n           */\n          enabled?: boolean\n          action?: cloudwatch.IAlarmAction\n          /** Whether to attach OK actions for this alarm. @default true */\n          enableOkAlarm?: boolean\n          /** @default 5% of allocated storage */\n          threshold?: cdk.Size\n        }\n        appendToAlarmDescription?: string\n      }\n\n      /**\n       * CPU utilization alarm overrides.\n       */\n      cpuUtilizationAlarm?: {\n        enabled?: boolean\n        /** Whether to attach OK actions for this alarm. @default true */\n        enableOkAlarm?: boolean\n        action?: cloudwatch.IAlarmAction\n        /** @default 80 */\n        threshold?: number\n        /** @default 5 */\n        evaluationPeriods?: number\n        /** @default 2 minutes */\n        period?: cdk.Duration\n        appendToAlarmDescription?: string\n      }\n    }\n\nexport interface DatabaseProps extends cdk.StackProps {\n  vpc: ec2.IVpc\n  engine: rds.IInstanceEngine\n  /**\n   * @default master\n   */\n  masterUsername?: string\n  /**\n   * @default app\n   */\n  databaseName?: string\n  /**\n   * @default 25\n   */\n  allocatedStorageGb?: number\n  instanceType: ec2.InstanceType\n  instanceIdentifier: string\n  /**\n   * @default true\n   */\n  isMultiAz?: boolean\n  /**\n   * Must not be removed once it has been set, as changing this\n   * results in a new DB instance being created.\n   *\n   * Also, remember to give database a new name when changing this prop, or else\n   * the new instance name will crash with the existing instance.\n   */\n  snapshotIdentifier?: string\n  /**\n   * @default false\n   */\n  usePublicSubnets?: boolean\n  overrideDbOptions?: Partial<rds.DatabaseInstanceSourceProps>\n  /**\n   * Configure database alarms.\n   *\n   * This property is required and must be one of two shapes:\n   *  - `{ enabled: false }` to explicitly disable automatic alarms\n   *  - `{ alarmAction, warningAction }` to enable alarms and provide both channels\n   *\n   * Default: enabled.\n   */\n  alarms: DatabaseAlarmsConfig\n}\n\nexport class Database extends constructs.Construct {\n  public readonly secret: sm.ISecret\n  public readonly connections: ec2.Connections\n  public readonly databaseInstance: rds.IDatabaseInstance\n  public readonly instanceType: ec2.InstanceType\n  public readonly allocatedStorage: cdk.Size\n\n  constructor(scope: constructs.Construct, id: string, props: DatabaseProps) {\n    super(scope, id)\n\n    const masterUsername = props.masterUsername ?? \"master\"\n    const databaseName = props.databaseName ?? \"app\"\n\n    const secret = new rds.DatabaseSecret(this, \"Secret\", {\n      username: masterUsername,\n    })\n\n    const options: rds.DatabaseInstanceSourceProps = {\n      engine: props.engine,\n      allowMajorVersionUpgrade: true,\n      instanceIdentifier: props.instanceIdentifier,\n      instanceType: props.instanceType,\n      vpc: props.vpc,\n      vpcSubnets: props.usePublicSubnets\n        ? {\n            subnetType: ec2.SubnetType.PUBLIC,\n          }\n        : undefined,\n      multiAz: props.isMultiAz ?? true,\n      // We default to 25 GiB storage instead of 100 GiB\n      // if we do not specify.\n      allocatedStorage: props.allocatedStorageGb ?? 25,\n      // We specify maximum backup retention.\n      backupRetention: cdk.Duration.days(35),\n      ...props.overrideDbOptions,\n    }\n    this.allocatedStorage = cdk.Size.gibibytes(options.allocatedStorage!)\n    this.instanceType = options.instanceType!\n\n    const db = props.snapshotIdentifier\n      ? new rds.DatabaseInstanceFromSnapshot(this, \"Resource\", {\n          ...options,\n          snapshotIdentifier: props.snapshotIdentifier,\n          credentials: rds.SnapshotCredentials.fromSecret(secret),\n        })\n      : new rds.DatabaseInstance(this, \"Resource\", {\n          ...options,\n          databaseName,\n          credentials: rds.Credentials.fromSecret(secret),\n          storageEncrypted: true,\n        })\n\n    this.databaseInstance = db\n\n    this.secret = db.secret!\n    this.connections = db.connections\n\n    // Override in case we have placed it in a public subnet.\n    // It would default to being public accessible which we do not want.\n    ;(db.node.defaultChild as rds.CfnDBInstance).publiclyAccessible = false\n\n    if (\"alarmAction\" in props.alarms) {\n      const alarms = props.alarms\n\n      const dbAlarms = new DatabaseAlarms(this, \"Alarms\", {\n        instanceIdentifier: props.instanceIdentifier,\n        instanceType: props.instanceType,\n        allocatedStorage: cdk.Size.gibibytes(options.allocatedStorage!),\n        alarmAction: alarms.alarmAction,\n        warningAction: alarms.warningAction,\n      })\n\n      // Default mapping:\n      // - low CPU credits -> alarm\n      // - critically low storage -> alarm\n      // - low storage -> warning\n      // - high CPU utilization -> warning\n      // Only create the CPU credits alarm if the instance type is burstable.\n      if (\n        this.instanceType.isBurstable() &&\n        alarms.cpuCreditsAlarm?.enabled !== false\n      ) {\n        dbAlarms.addCpuCreditsAlarm({\n          action: alarms.cpuCreditsAlarm?.action,\n          threshold: alarms.cpuCreditsAlarm?.threshold,\n          enableOkAlarm: alarms.cpuCreditsAlarm?.enableOkAlarm,\n          appendToAlarmDescription:\n            alarms.cpuCreditsAlarm?.appendToAlarmDescription,\n        })\n      }\n\n      if (alarms.storageSpaceAlarms) {\n        dbAlarms.addStorageSpaceAlarms({\n          enabled: alarms.storageSpaceAlarms.enabled,\n          lowStorageSpaceAlarm: alarms.storageSpaceAlarms.lowStorageSpaceAlarm,\n          criticallyLowStorageSpaceAlarm:\n            alarms.storageSpaceAlarms.criticallyLowStorageSpaceAlarm,\n          appendToAlarmDescription:\n            alarms.storageSpaceAlarms.appendToAlarmDescription,\n        })\n      }\n\n      if (alarms.cpuUtilizationAlarm?.enabled !== false) {\n        dbAlarms.addCpuUtilizationAlarm({\n          action: alarms.cpuUtilizationAlarm?.action,\n          threshold: alarms.cpuUtilizationAlarm?.threshold,\n          evaluationPeriods: alarms.cpuUtilizationAlarm?.evaluationPeriods,\n          period: alarms.cpuUtilizationAlarm?.period,\n          enableOkAlarm: alarms.cpuUtilizationAlarm?.enableOkAlarm,\n          appendToAlarmDescription:\n            alarms.cpuUtilizationAlarm?.appendToAlarmDescription,\n        })\n      }\n    }\n  }\n\n  public allowConnectionFrom(source: ec2.ISecurityGroup): void {\n    this.connections.allowDefaultPortFrom(source)\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@liflig/cdk",
|
|
3
|
-
"version": "3.24.
|
|
3
|
+
"version": "3.24.3",
|
|
4
4
|
"description": "CDK library for Liflig",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"repository": {
|
|
@@ -68,7 +68,7 @@
|
|
|
68
68
|
"semantic-release": "25.0.3",
|
|
69
69
|
"ts-jest": "29.4.9",
|
|
70
70
|
"tsx": "4.21.0",
|
|
71
|
-
"typedoc": "0.28.
|
|
71
|
+
"typedoc": "0.28.19",
|
|
72
72
|
"typescript": "5.9.3"
|
|
73
73
|
},
|
|
74
74
|
"dependencies": {
|