@liflig/cdk 3.22.19 → 3.23.0
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/README.md +32 -0
- package/assets/slack-error-log-handler-lambda/.python-version +1 -0
- 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.2.pyc +0 -0
- package/assets/slack-error-log-handler-lambda/index.py +411 -0
- package/assets/slack-error-log-handler-lambda/pyproject.toml +13 -0
- package/assets/slack-error-log-handler-lambda/test_handler.py +229 -0
- package/assets/slack-error-log-handler-lambda/uv.lock +176 -0
- package/lib/alarms/database-alarms.d.ts +31 -18
- package/lib/alarms/database-alarms.js +39 -18
- package/lib/alarms/index.d.ts +2 -0
- package/lib/alarms/index.js +2 -1
- package/lib/alarms/lambda-alarms.d.ts +116 -14
- package/lib/alarms/lambda-alarms.js +158 -29
- package/lib/alarms/log-filter-patterns.d.ts +5 -0
- package/lib/alarms/log-filter-patterns.js +6 -0
- package/lib/alarms/queue-alarms.d.ts +88 -0
- package/lib/alarms/queue-alarms.js +109 -0
- package/lib/alarms/service-alarms.d.ts +75 -8
- package/lib/alarms/service-alarms.js +130 -38
- package/lib/alarms/slack-alarm.d.ts +6 -1
- package/lib/alarms/slack-alarm.js +23 -5
- package/lib/ecs/fargate-service.d.ts +111 -1
- package/lib/ecs/fargate-service.js +46 -2
- package/lib/load-balancer/load-balancer.js +2 -2
- package/lib/rds/database.d.ts +83 -0
- package/lib/rds/database.js +41 -1
- package/package.json +1 -1
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
version = 1
|
|
2
|
+
revision = 3
|
|
3
|
+
requires-python = ">=3.14"
|
|
4
|
+
|
|
5
|
+
[[package]]
|
|
6
|
+
name = "boto3"
|
|
7
|
+
version = "1.42.84"
|
|
8
|
+
source = { registry = "https://pypi.org/simple" }
|
|
9
|
+
dependencies = [
|
|
10
|
+
{ name = "botocore" },
|
|
11
|
+
{ name = "jmespath" },
|
|
12
|
+
{ name = "s3transfer" },
|
|
13
|
+
]
|
|
14
|
+
sdist = { url = "https://files.pythonhosted.org/packages/88/89/2d647bd717da55a8cc68602b197f53a5fa36fb95a2f9e76c4aff11a9cfd1/boto3-1.42.84.tar.gz", hash = "sha256:6a84b3293a5d8b3adf827a54588e7dcffcf0a85410d7dadca615544f97d27579", size = 112816, upload-time = "2026-04-06T19:39:07.585Z" }
|
|
15
|
+
wheels = [
|
|
16
|
+
{ url = "https://files.pythonhosted.org/packages/2d/31/cdf4326841613d1d181a77b3038a988800fb3373ca50de1639fba9fa87de/boto3-1.42.84-py3-none-any.whl", hash = "sha256:4d03ad3211832484037337292586f71f48707141288d9ac23049c04204f4ab03", size = 140555, upload-time = "2026-04-06T19:39:06.009Z" },
|
|
17
|
+
]
|
|
18
|
+
|
|
19
|
+
[[package]]
|
|
20
|
+
name = "botocore"
|
|
21
|
+
version = "1.42.84"
|
|
22
|
+
source = { registry = "https://pypi.org/simple" }
|
|
23
|
+
dependencies = [
|
|
24
|
+
{ name = "jmespath" },
|
|
25
|
+
{ name = "python-dateutil" },
|
|
26
|
+
{ name = "urllib3" },
|
|
27
|
+
]
|
|
28
|
+
sdist = { url = "https://files.pythonhosted.org/packages/b4/b7/1c03423843fb0d1795b686511c00ee63fed1234c2400f469aeedfd42212f/botocore-1.42.84.tar.gz", hash = "sha256:234064604c80d9272a5e9f6b3566d260bcaa053a5e05246db90d7eca1c2cf44b", size = 15148615, upload-time = "2026-04-06T19:38:56.673Z" }
|
|
29
|
+
wheels = [
|
|
30
|
+
{ url = "https://files.pythonhosted.org/packages/e3/37/0c0c90361c8a1b9e6c75222ca24ae12996a298c0e18822a72ab229c37207/botocore-1.42.84-py3-none-any.whl", hash = "sha256:15f3fe07dfa6545e46a60c4b049fe2bdf63803c595ae4a4eec90e8f8172764f3", size = 14827061, upload-time = "2026-04-06T19:38:53.613Z" },
|
|
31
|
+
]
|
|
32
|
+
|
|
33
|
+
[[package]]
|
|
34
|
+
name = "colorama"
|
|
35
|
+
version = "0.4.6"
|
|
36
|
+
source = { registry = "https://pypi.org/simple" }
|
|
37
|
+
sdist = { url = "https://files.pythonhosted.org/packages/d8/53/6f443c9a4a8358a93a6792e2acffb9d9d5cb0a5cfd8802644b7b1c9a02e4/colorama-0.4.6.tar.gz", hash = "sha256:08695f5cb7ed6e0531a20572697297273c47b8cae5a63ffc6d6ed5c201be6e44", size = 27697, upload-time = "2022-10-25T02:36:22.414Z" }
|
|
38
|
+
wheels = [
|
|
39
|
+
{ url = "https://files.pythonhosted.org/packages/d1/d6/3965ed04c63042e047cb6a3e6ed1a63a35087b6a609aa3a15ed8ac56c221/colorama-0.4.6-py2.py3-none-any.whl", hash = "sha256:4f1d9991f5acc0ca119f9d443620b77f9d6b33703e51011c16baf57afb285fc6", size = 25335, upload-time = "2022-10-25T02:36:20.889Z" },
|
|
40
|
+
]
|
|
41
|
+
|
|
42
|
+
[[package]]
|
|
43
|
+
name = "iniconfig"
|
|
44
|
+
version = "2.3.0"
|
|
45
|
+
source = { registry = "https://pypi.org/simple" }
|
|
46
|
+
sdist = { url = "https://files.pythonhosted.org/packages/72/34/14ca021ce8e5dfedc35312d08ba8bf51fdd999c576889fc2c24cb97f4f10/iniconfig-2.3.0.tar.gz", hash = "sha256:c76315c77db068650d49c5b56314774a7804df16fee4402c1f19d6d15d8c4730", size = 20503, upload-time = "2025-10-18T21:55:43.219Z" }
|
|
47
|
+
wheels = [
|
|
48
|
+
{ url = "https://files.pythonhosted.org/packages/cb/b1/3846dd7f199d53cb17f49cba7e651e9ce294d8497c8c150530ed11865bb8/iniconfig-2.3.0-py3-none-any.whl", hash = "sha256:f631c04d2c48c52b84d0d0549c99ff3859c98df65b3101406327ecc7d53fbf12", size = 7484, upload-time = "2025-10-18T21:55:41.639Z" },
|
|
49
|
+
]
|
|
50
|
+
|
|
51
|
+
[[package]]
|
|
52
|
+
name = "jmespath"
|
|
53
|
+
version = "1.1.0"
|
|
54
|
+
source = { registry = "https://pypi.org/simple" }
|
|
55
|
+
sdist = { url = "https://files.pythonhosted.org/packages/d3/59/322338183ecda247fb5d1763a6cbe46eff7222eaeebafd9fa65d4bf5cb11/jmespath-1.1.0.tar.gz", hash = "sha256:472c87d80f36026ae83c6ddd0f1d05d4e510134ed462851fd5f754c8c3cbb88d", size = 27377, upload-time = "2026-01-22T16:35:26.279Z" }
|
|
56
|
+
wheels = [
|
|
57
|
+
{ url = "https://files.pythonhosted.org/packages/14/2f/967ba146e6d58cf6a652da73885f52fc68001525b4197effc174321d70b4/jmespath-1.1.0-py3-none-any.whl", hash = "sha256:a5663118de4908c91729bea0acadca56526eb2698e83de10cd116ae0f4e97c64", size = 20419, upload-time = "2026-01-22T16:35:24.919Z" },
|
|
58
|
+
]
|
|
59
|
+
|
|
60
|
+
[[package]]
|
|
61
|
+
name = "packaging"
|
|
62
|
+
version = "26.0"
|
|
63
|
+
source = { registry = "https://pypi.org/simple" }
|
|
64
|
+
sdist = { url = "https://files.pythonhosted.org/packages/65/ee/299d360cdc32edc7d2cf530f3accf79c4fca01e96ffc950d8a52213bd8e4/packaging-26.0.tar.gz", hash = "sha256:00243ae351a257117b6a241061796684b084ed1c516a08c48a3f7e147a9d80b4", size = 143416, upload-time = "2026-01-21T20:50:39.064Z" }
|
|
65
|
+
wheels = [
|
|
66
|
+
{ url = "https://files.pythonhosted.org/packages/b7/b9/c538f279a4e237a006a2c98387d081e9eb060d203d8ed34467cc0f0b9b53/packaging-26.0-py3-none-any.whl", hash = "sha256:b36f1fef9334a5588b4166f8bcd26a14e521f2b55e6b9de3aaa80d3ff7a37529", size = 74366, upload-time = "2026-01-21T20:50:37.788Z" },
|
|
67
|
+
]
|
|
68
|
+
|
|
69
|
+
[[package]]
|
|
70
|
+
name = "pluggy"
|
|
71
|
+
version = "1.6.0"
|
|
72
|
+
source = { registry = "https://pypi.org/simple" }
|
|
73
|
+
sdist = { url = "https://files.pythonhosted.org/packages/f9/e2/3e91f31a7d2b083fe6ef3fa267035b518369d9511ffab804f839851d2779/pluggy-1.6.0.tar.gz", hash = "sha256:7dcc130b76258d33b90f61b658791dede3486c3e6bfb003ee5c9bfb396dd22f3", size = 69412, upload-time = "2025-05-15T12:30:07.975Z" }
|
|
74
|
+
wheels = [
|
|
75
|
+
{ url = "https://files.pythonhosted.org/packages/54/20/4d324d65cc6d9205fabedc306948156824eb9f0ee1633355a8f7ec5c66bf/pluggy-1.6.0-py3-none-any.whl", hash = "sha256:e920276dd6813095e9377c0bc5566d94c932c33b27a3e3945d8389c374dd4746", size = 20538, upload-time = "2025-05-15T12:30:06.134Z" },
|
|
76
|
+
]
|
|
77
|
+
|
|
78
|
+
[[package]]
|
|
79
|
+
name = "pygments"
|
|
80
|
+
version = "2.20.0"
|
|
81
|
+
source = { registry = "https://pypi.org/simple" }
|
|
82
|
+
sdist = { url = "https://files.pythonhosted.org/packages/c3/b2/bc9c9196916376152d655522fdcebac55e66de6603a76a02bca1b6414f6c/pygments-2.20.0.tar.gz", hash = "sha256:6757cd03768053ff99f3039c1a36d6c0aa0b263438fcab17520b30a303a82b5f", size = 4955991, upload-time = "2026-03-29T13:29:33.898Z" }
|
|
83
|
+
wheels = [
|
|
84
|
+
{ url = "https://files.pythonhosted.org/packages/f4/7e/a72dd26f3b0f4f2bf1dd8923c85f7ceb43172af56d63c7383eb62b332364/pygments-2.20.0-py3-none-any.whl", hash = "sha256:81a9e26dd42fd28a23a2d169d86d7ac03b46e2f8b59ed4698fb4785f946d0176", size = 1231151, upload-time = "2026-03-29T13:29:30.038Z" },
|
|
85
|
+
]
|
|
86
|
+
|
|
87
|
+
[[package]]
|
|
88
|
+
name = "pytest"
|
|
89
|
+
version = "9.0.2"
|
|
90
|
+
source = { registry = "https://pypi.org/simple" }
|
|
91
|
+
dependencies = [
|
|
92
|
+
{ name = "colorama", marker = "sys_platform == 'win32'" },
|
|
93
|
+
{ name = "iniconfig" },
|
|
94
|
+
{ name = "packaging" },
|
|
95
|
+
{ name = "pluggy" },
|
|
96
|
+
{ name = "pygments" },
|
|
97
|
+
]
|
|
98
|
+
sdist = { url = "https://files.pythonhosted.org/packages/d1/db/7ef3487e0fb0049ddb5ce41d3a49c235bf9ad299b6a25d5780a89f19230f/pytest-9.0.2.tar.gz", hash = "sha256:75186651a92bd89611d1d9fc20f0b4345fd827c41ccd5c299a868a05d70edf11", size = 1568901, upload-time = "2025-12-06T21:30:51.014Z" }
|
|
99
|
+
wheels = [
|
|
100
|
+
{ url = "https://files.pythonhosted.org/packages/3b/ab/b3226f0bd7cdcf710fbede2b3548584366da3b19b5021e74f5bde2a8fa3f/pytest-9.0.2-py3-none-any.whl", hash = "sha256:711ffd45bf766d5264d487b917733b453d917afd2b0ad65223959f59089f875b", size = 374801, upload-time = "2025-12-06T21:30:49.154Z" },
|
|
101
|
+
]
|
|
102
|
+
|
|
103
|
+
[[package]]
|
|
104
|
+
name = "pytest-mock"
|
|
105
|
+
version = "3.15.1"
|
|
106
|
+
source = { registry = "https://pypi.org/simple" }
|
|
107
|
+
dependencies = [
|
|
108
|
+
{ name = "pytest" },
|
|
109
|
+
]
|
|
110
|
+
sdist = { url = "https://files.pythonhosted.org/packages/68/14/eb014d26be205d38ad5ad20d9a80f7d201472e08167f0bb4361e251084a9/pytest_mock-3.15.1.tar.gz", hash = "sha256:1849a238f6f396da19762269de72cb1814ab44416fa73a8686deac10b0d87a0f", size = 34036, upload-time = "2025-09-16T16:37:27.081Z" }
|
|
111
|
+
wheels = [
|
|
112
|
+
{ url = "https://files.pythonhosted.org/packages/5a/cc/06253936f4a7fa2e0f48dfe6d851d9c56df896a9ab09ac019d70b760619c/pytest_mock-3.15.1-py3-none-any.whl", hash = "sha256:0a25e2eb88fe5168d535041d09a4529a188176ae608a6d249ee65abc0949630d", size = 10095, upload-time = "2025-09-16T16:37:25.734Z" },
|
|
113
|
+
]
|
|
114
|
+
|
|
115
|
+
[[package]]
|
|
116
|
+
name = "python-dateutil"
|
|
117
|
+
version = "2.9.0.post0"
|
|
118
|
+
source = { registry = "https://pypi.org/simple" }
|
|
119
|
+
dependencies = [
|
|
120
|
+
{ name = "six" },
|
|
121
|
+
]
|
|
122
|
+
sdist = { url = "https://files.pythonhosted.org/packages/66/c0/0c8b6ad9f17a802ee498c46e004a0eb49bc148f2fd230864601a86dcf6db/python-dateutil-2.9.0.post0.tar.gz", hash = "sha256:37dd54208da7e1cd875388217d5e00ebd4179249f90fb72437e91a35459a0ad3", size = 342432, upload-time = "2024-03-01T18:36:20.211Z" }
|
|
123
|
+
wheels = [
|
|
124
|
+
{ url = "https://files.pythonhosted.org/packages/ec/57/56b9bcc3c9c6a792fcbaf139543cee77261f3651ca9da0c93f5c1221264b/python_dateutil-2.9.0.post0-py2.py3-none-any.whl", hash = "sha256:a8b2bc7bffae282281c8140a97d3aa9c14da0b136dfe83f850eea9a5f7470427", size = 229892, upload-time = "2024-03-01T18:36:18.57Z" },
|
|
125
|
+
]
|
|
126
|
+
|
|
127
|
+
[[package]]
|
|
128
|
+
name = "s3transfer"
|
|
129
|
+
version = "0.16.0"
|
|
130
|
+
source = { registry = "https://pypi.org/simple" }
|
|
131
|
+
dependencies = [
|
|
132
|
+
{ name = "botocore" },
|
|
133
|
+
]
|
|
134
|
+
sdist = { url = "https://files.pythonhosted.org/packages/05/04/74127fc843314818edfa81b5540e26dd537353b123a4edc563109d8f17dd/s3transfer-0.16.0.tar.gz", hash = "sha256:8e990f13268025792229cd52fa10cb7163744bf56e719e0b9cb925ab79abf920", size = 153827, upload-time = "2025-12-01T02:30:59.114Z" }
|
|
135
|
+
wheels = [
|
|
136
|
+
{ url = "https://files.pythonhosted.org/packages/fc/51/727abb13f44c1fcf6d145979e1535a35794db0f6e450a0cb46aa24732fe2/s3transfer-0.16.0-py3-none-any.whl", hash = "sha256:18e25d66fed509e3868dc1572b3f427ff947dd2c56f844a5bf09481ad3f3b2fe", size = 86830, upload-time = "2025-12-01T02:30:57.729Z" },
|
|
137
|
+
]
|
|
138
|
+
|
|
139
|
+
[[package]]
|
|
140
|
+
name = "six"
|
|
141
|
+
version = "1.17.0"
|
|
142
|
+
source = { registry = "https://pypi.org/simple" }
|
|
143
|
+
sdist = { url = "https://files.pythonhosted.org/packages/94/e7/b2c673351809dca68a0e064b6af791aa332cf192da575fd474ed7d6f16a2/six-1.17.0.tar.gz", hash = "sha256:ff70335d468e7eb6ec65b95b99d3a2836546063f63acc5171de367e834932a81", size = 34031, upload-time = "2024-12-04T17:35:28.174Z" }
|
|
144
|
+
wheels = [
|
|
145
|
+
{ url = "https://files.pythonhosted.org/packages/b7/ce/149a00dd41f10bc29e5921b496af8b574d8413afcd5e30dfa0ed46c2cc5e/six-1.17.0-py2.py3-none-any.whl", hash = "sha256:4721f391ed90541fddacab5acf947aa0d3dc7d27b2e1e8eda2be8970586c3274", size = 11050, upload-time = "2024-12-04T17:35:26.475Z" },
|
|
146
|
+
]
|
|
147
|
+
|
|
148
|
+
[[package]]
|
|
149
|
+
name = "slack-error-log-handler-lambda"
|
|
150
|
+
version = "0.0.0"
|
|
151
|
+
source = { virtual = "." }
|
|
152
|
+
|
|
153
|
+
[package.dev-dependencies]
|
|
154
|
+
dev = [
|
|
155
|
+
{ name = "boto3" },
|
|
156
|
+
{ name = "pytest" },
|
|
157
|
+
{ name = "pytest-mock" },
|
|
158
|
+
]
|
|
159
|
+
|
|
160
|
+
[package.metadata]
|
|
161
|
+
|
|
162
|
+
[package.metadata.requires-dev]
|
|
163
|
+
dev = [
|
|
164
|
+
{ name = "boto3", specifier = ">=1.26" },
|
|
165
|
+
{ name = "pytest", specifier = ">=7.0" },
|
|
166
|
+
{ name = "pytest-mock", specifier = ">=3.0" },
|
|
167
|
+
]
|
|
168
|
+
|
|
169
|
+
[[package]]
|
|
170
|
+
name = "urllib3"
|
|
171
|
+
version = "2.6.3"
|
|
172
|
+
source = { registry = "https://pypi.org/simple" }
|
|
173
|
+
sdist = { url = "https://files.pythonhosted.org/packages/c7/24/5f1b3bdffd70275f6661c76461e25f024d5a38a46f04aaca912426a2b1d3/urllib3-2.6.3.tar.gz", hash = "sha256:1b62b6884944a57dbe321509ab94fd4d3b307075e0c2eae991ac71ee15ad38ed", size = 435556, upload-time = "2026-01-07T16:24:43.925Z" }
|
|
174
|
+
wheels = [
|
|
175
|
+
{ url = "https://files.pythonhosted.org/packages/39/08/aaaad47bc4e9dc8c725e68f9d04865dbcb2052843ff09c97b08904852d84/urllib3-2.6.3-py3-none-any.whl", hash = "sha256:bf272323e553dfb2e87d9bfd225ca7b0f467b919d7bbd355436d3fd37cb0acd4", size = 131584, upload-time = "2026-01-07T16:24:42.685Z" },
|
|
176
|
+
]
|
|
@@ -4,15 +4,22 @@ import type * as ec2 from "aws-cdk-lib/aws-ec2";
|
|
|
4
4
|
import * as constructs from "constructs";
|
|
5
5
|
export interface DatabaseAlarmsProps {
|
|
6
6
|
/**
|
|
7
|
-
* The
|
|
7
|
+
* The action to use for alarms sent to "alarms" Slack channel,
|
|
8
|
+
* e.g., critical alerts.
|
|
8
9
|
*/
|
|
9
|
-
|
|
10
|
+
alarmAction: cloudwatch.IAlarmAction;
|
|
11
|
+
/**
|
|
12
|
+
* The action to use for alarms sent to "warning" Slack channel,
|
|
13
|
+
* e.g., less critical alerts.
|
|
14
|
+
*/
|
|
15
|
+
warningAction: cloudwatch.IAlarmAction;
|
|
10
16
|
instanceIdentifier: string;
|
|
11
17
|
instanceType: ec2.InstanceType;
|
|
12
18
|
allocatedStorage: cdk.Size;
|
|
13
19
|
}
|
|
14
20
|
export declare class DatabaseAlarms extends constructs.Construct {
|
|
15
|
-
private readonly
|
|
21
|
+
private readonly alarmAction;
|
|
22
|
+
private readonly warningAction;
|
|
16
23
|
private readonly databaseInstanceIdentifier;
|
|
17
24
|
private readonly instanceType;
|
|
18
25
|
private readonly allocatedStorage;
|
|
@@ -44,6 +51,10 @@ export declare class DatabaseAlarms extends constructs.Construct {
|
|
|
44
51
|
* @default 10% of the maximum earned CPU credits for the instance type.
|
|
45
52
|
*/
|
|
46
53
|
threshold?: number;
|
|
54
|
+
/**
|
|
55
|
+
* @default true
|
|
56
|
+
*/
|
|
57
|
+
enableOkAlarm?: boolean;
|
|
47
58
|
/**
|
|
48
59
|
* Add extra information to the alarm description, like Runbook URL or steps to triage.
|
|
49
60
|
*/
|
|
@@ -52,22 +63,18 @@ export declare class DatabaseAlarms extends constructs.Construct {
|
|
|
52
63
|
/**
|
|
53
64
|
* Sets up two CloudWatch Alarms for monitoring disk storage space:
|
|
54
65
|
* 1) one that triggers if the available disk storage space is low.
|
|
55
|
-
* 2) one that triggers if the available disk storage space is
|
|
66
|
+
* 2) one that triggers if the available disk storage space is critically low.
|
|
56
67
|
*
|
|
57
68
|
* You may want to use different alarm actions for the two alarms, e.g., one can be
|
|
58
69
|
* categorized as a "warning", while the other one can be considered an "alarm".
|
|
59
70
|
*/
|
|
60
71
|
addStorageSpaceAlarms(props?: {
|
|
61
72
|
/**
|
|
62
|
-
*
|
|
63
|
-
*
|
|
64
|
-
* @default Configured with sane defaults.
|
|
73
|
+
* Set to `false` to disable both storage space alarms (low + critically low).
|
|
74
|
+
* @default true
|
|
65
75
|
*/
|
|
76
|
+
enabled?: boolean;
|
|
66
77
|
lowStorageSpaceAlarm?: {
|
|
67
|
-
/**
|
|
68
|
-
* @default true
|
|
69
|
-
*/
|
|
70
|
-
enabled?: boolean;
|
|
71
78
|
/**
|
|
72
79
|
* An action to use for CloudWatch alarm state changes instead of the default action
|
|
73
80
|
*/
|
|
@@ -76,17 +83,15 @@ export declare class DatabaseAlarms extends constructs.Construct {
|
|
|
76
83
|
* @default 25% of the allocated storage.
|
|
77
84
|
*/
|
|
78
85
|
threshold?: cdk.Size;
|
|
86
|
+
/**
|
|
87
|
+
* Whether to attach OK actions for this alarm. @default true
|
|
88
|
+
*/
|
|
89
|
+
enableOkAlarm?: boolean;
|
|
79
90
|
};
|
|
80
91
|
/**
|
|
81
|
-
* Configuration for
|
|
82
|
-
*
|
|
83
|
-
* @default Configured with sane defaults.
|
|
92
|
+
* Configuration for critically low storage alarm.
|
|
84
93
|
*/
|
|
85
94
|
criticallyLowStorageSpaceAlarm?: {
|
|
86
|
-
/**
|
|
87
|
-
* @default true
|
|
88
|
-
*/
|
|
89
|
-
enabled?: boolean;
|
|
90
95
|
/**
|
|
91
96
|
* An action to use for CloudWatch alarm state changes instead of the default action
|
|
92
97
|
*/
|
|
@@ -95,6 +100,10 @@ export declare class DatabaseAlarms extends constructs.Construct {
|
|
|
95
100
|
* @default 5% of the allocated storage.
|
|
96
101
|
*/
|
|
97
102
|
threshold?: cdk.Size;
|
|
103
|
+
/**
|
|
104
|
+
* Whether to attach OK actions for this alarm. @default true
|
|
105
|
+
*/
|
|
106
|
+
enableOkAlarm?: boolean;
|
|
98
107
|
};
|
|
99
108
|
/**
|
|
100
109
|
* Add extra information to the alarm description, like Runbook URL or steps to triage.
|
|
@@ -129,6 +138,10 @@ export declare class DatabaseAlarms extends constructs.Construct {
|
|
|
129
138
|
* @default 2 minutes
|
|
130
139
|
*/
|
|
131
140
|
period?: cdk.Duration;
|
|
141
|
+
/**
|
|
142
|
+
* Whether to attach OK actions for this alarm. @default true
|
|
143
|
+
*/
|
|
144
|
+
enableOkAlarm?: boolean;
|
|
132
145
|
/**
|
|
133
146
|
* Add extra information to the alarm description, like Runbook URL or steps to triage.
|
|
134
147
|
*/
|
|
@@ -33,13 +33,15 @@ const cpuCreditBalanceByInstanceType = {
|
|
|
33
33
|
"t4g.2xlarge": 4608,
|
|
34
34
|
};
|
|
35
35
|
export class DatabaseAlarms extends constructs.Construct {
|
|
36
|
-
|
|
36
|
+
alarmAction;
|
|
37
|
+
warningAction;
|
|
37
38
|
databaseInstanceIdentifier;
|
|
38
39
|
instanceType;
|
|
39
40
|
allocatedStorage;
|
|
40
41
|
constructor(scope, id, props) {
|
|
41
42
|
super(scope, id);
|
|
42
|
-
this.
|
|
43
|
+
this.alarmAction = props.alarmAction;
|
|
44
|
+
this.warningAction = props.warningAction;
|
|
43
45
|
this.databaseInstanceIdentifier = props.instanceIdentifier;
|
|
44
46
|
this.instanceType = props.instanceType;
|
|
45
47
|
this.allocatedStorage = props.allocatedStorage;
|
|
@@ -59,15 +61,18 @@ export class DatabaseAlarms extends constructs.Construct {
|
|
|
59
61
|
* @default Configured with sane defaults.
|
|
60
62
|
*/
|
|
61
63
|
props) {
|
|
64
|
+
// CPU credits alarms are only applicable to burstable instance types.
|
|
65
|
+
// Explicitly throw if a caller tries to create this alarm for a
|
|
66
|
+
// non-burstable instance.
|
|
62
67
|
if (!this.instanceType.isBurstable()) {
|
|
63
|
-
throw new Error(
|
|
68
|
+
throw new Error(`addCpuCreditsAlarm: instance type '${this.instanceType.toString()}' is not burstable; this alarm is only applicable to burstable instance types.`);
|
|
64
69
|
}
|
|
65
70
|
const defaultThreshold = cpuCreditBalanceByInstanceType[this.instanceType.toString()] * 0.1;
|
|
66
71
|
const threshold = props?.threshold ?? defaultThreshold;
|
|
67
72
|
if (!threshold) {
|
|
68
73
|
throw new Error(`No threshold supplied, and unable to determine a default value for instance type '${this.instanceType.toString()}'`);
|
|
69
74
|
}
|
|
70
|
-
new cloudwatch.Metric({
|
|
75
|
+
const creditsAlarm = new cloudwatch.Metric({
|
|
71
76
|
metricName: "CPUCreditBalance",
|
|
72
77
|
namespace: "AWS/RDS",
|
|
73
78
|
statistic: "Minimum",
|
|
@@ -75,8 +80,7 @@ export class DatabaseAlarms extends constructs.Construct {
|
|
|
75
80
|
dimensionsMap: {
|
|
76
81
|
DBInstanceIdentifier: this.databaseInstanceIdentifier,
|
|
77
82
|
},
|
|
78
|
-
})
|
|
79
|
-
.createAlarm(this, "CreditsAlarm", {
|
|
83
|
+
}).createAlarm(this, "CreditsAlarm", {
|
|
80
84
|
alarmDescription: `Less than ${threshold} CPU credits remaining for RDS database '${this.databaseInstanceIdentifier}'. ${this.instanceType.toString().startsWith("t2.")
|
|
81
85
|
? "If this reaches 0, the instance will be limited to a baseline CPU utilization."
|
|
82
86
|
: "If the balance is depleted, AWS adds additional charges."} ${props?.appendToAlarmDescription ?? ""}`,
|
|
@@ -84,18 +88,26 @@ export class DatabaseAlarms extends constructs.Construct {
|
|
|
84
88
|
evaluationPeriods: 1,
|
|
85
89
|
threshold: threshold,
|
|
86
90
|
treatMissingData: cloudwatch.TreatMissingData.IGNORE,
|
|
87
|
-
})
|
|
88
|
-
|
|
91
|
+
});
|
|
92
|
+
// Default to the alarm action
|
|
93
|
+
creditsAlarm.addAlarmAction(props?.action ?? this.alarmAction);
|
|
94
|
+
if (props?.enableOkAlarm ?? true) {
|
|
95
|
+
creditsAlarm.addOkAction(props?.action ?? this.alarmAction);
|
|
96
|
+
}
|
|
89
97
|
}
|
|
90
98
|
/**
|
|
91
99
|
* Sets up two CloudWatch Alarms for monitoring disk storage space:
|
|
92
100
|
* 1) one that triggers if the available disk storage space is low.
|
|
93
|
-
* 2) one that triggers if the available disk storage space is
|
|
101
|
+
* 2) one that triggers if the available disk storage space is critically low.
|
|
94
102
|
*
|
|
95
103
|
* You may want to use different alarm actions for the two alarms, e.g., one can be
|
|
96
104
|
* categorized as a "warning", while the other one can be considered an "alarm".
|
|
97
105
|
*/
|
|
98
106
|
addStorageSpaceAlarms(props) {
|
|
107
|
+
// If the top-level enabled flag is explicitly false, do nothing
|
|
108
|
+
if (props?.enabled === false)
|
|
109
|
+
return;
|
|
110
|
+
// Create Low Storage Space alarm
|
|
99
111
|
const lowStorageSpaceAlarm = new cloudwatch.Metric({
|
|
100
112
|
metricName: "FreeStorageSpace",
|
|
101
113
|
namespace: "AWS/RDS",
|
|
@@ -112,10 +124,13 @@ export class DatabaseAlarms extends constructs.Construct {
|
|
|
112
124
|
this.allocatedStorage.toBytes() * 0.25,
|
|
113
125
|
treatMissingData: cloudwatch.TreatMissingData.IGNORE,
|
|
114
126
|
});
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
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);
|
|
118
132
|
}
|
|
133
|
+
// Create Critically Low Storage Space alarm
|
|
119
134
|
const criticallyLowStorageSpaceAlarm = new cloudwatch.Metric({
|
|
120
135
|
metricName: "FreeStorageSpace",
|
|
121
136
|
namespace: "AWS/RDS",
|
|
@@ -132,9 +147,11 @@ export class DatabaseAlarms extends constructs.Construct {
|
|
|
132
147
|
this.allocatedStorage.toBytes() * 0.05,
|
|
133
148
|
treatMissingData: cloudwatch.TreatMissingData.IGNORE,
|
|
134
149
|
});
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
150
|
+
// Default to the alarm action
|
|
151
|
+
const criticalAction = props?.criticallyLowStorageSpaceAlarm?.action ?? this.alarmAction;
|
|
152
|
+
criticallyLowStorageSpaceAlarm.addAlarmAction(criticalAction);
|
|
153
|
+
if (props?.criticallyLowStorageSpaceAlarm?.enableOkAlarm ?? true) {
|
|
154
|
+
criticallyLowStorageSpaceAlarm.addOkAction(criticalAction);
|
|
138
155
|
}
|
|
139
156
|
}
|
|
140
157
|
/**
|
|
@@ -163,8 +180,12 @@ export class DatabaseAlarms extends constructs.Construct {
|
|
|
163
180
|
threshold: props?.threshold ?? 80,
|
|
164
181
|
treatMissingData: cloudwatch.TreatMissingData.IGNORE,
|
|
165
182
|
});
|
|
166
|
-
|
|
167
|
-
|
|
183
|
+
// Default to the warning action
|
|
184
|
+
const cpuAction = props?.action ?? this.warningAction;
|
|
185
|
+
alarm.addAlarmAction(cpuAction);
|
|
186
|
+
if (props?.enableOkAlarm ?? true) {
|
|
187
|
+
alarm.addOkAction(cpuAction);
|
|
188
|
+
}
|
|
168
189
|
}
|
|
169
190
|
}
|
|
170
|
-
//# 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 default action to use for CloudWatch alarm state changes\n   */\n  action: 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 action: 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.action = props.action\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       * Add extra information to the alarm description, like Runbook URL or steps to triage.\n       */\n      appendToAlarmDescription?: string\n    },\n  ): void {\n    if (!this.instanceType.isBurstable()) {\n      throw new Error(\n        \"CPU credits are only relevant for 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    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    })\n      .createAlarm(this, \"CreditsAlarm\", {\n        alarmDescription: `Less than ${threshold} CPU credits remaining for RDS database '${\n          this.databaseInstanceIdentifier\n        }'. ${\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      .addAlarmAction(this.action)\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 critcally 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     * Configuration for an alarm.\n     *\n     * @default Configured with sane defaults.\n     */\n    lowStorageSpaceAlarm?: {\n      /**\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    /**\n     * Configuration for an alarm.\n     *\n     * @default Configured with sane defaults.\n     */\n    criticallyLowStorageSpaceAlarm?: {\n      /**\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    /**\n     * Add extra information to the alarm description, like Runbook URL or steps to triage.\n     */\n    appendToAlarmDescription?: string\n  }): void {\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    if (props?.lowStorageSpaceAlarm?.enabled ?? true) {\n      lowStorageSpaceAlarm.addAlarmAction(\n        props?.lowStorageSpaceAlarm?.action || this.action,\n      )\n      lowStorageSpaceAlarm.addOkAction(\n        props?.lowStorageSpaceAlarm?.action || this.action,\n      )\n    }\n\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    if (props?.criticallyLowStorageSpaceAlarm?.enabled ?? true) {\n      criticallyLowStorageSpaceAlarm.addAlarmAction(\n        props?.criticallyLowStorageSpaceAlarm?.action || this.action,\n      )\n      criticallyLowStorageSpaceAlarm.addOkAction(\n        props?.criticallyLowStorageSpaceAlarm?.action || this.action,\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       * 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    alarm.addAlarmAction(props?.action ?? this.action)\n    alarm.addOkAction(props?.action ?? this.action)\n  }\n}\n"]}
|
|
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"]}
|
package/lib/alarms/index.d.ts
CHANGED
|
@@ -2,6 +2,8 @@ export type { DatabaseAlarmsProps } from "./database-alarms";
|
|
|
2
2
|
export { DatabaseAlarms } from "./database-alarms";
|
|
3
3
|
export type { LambdaAlarmsProps } from "./lambda-alarms";
|
|
4
4
|
export { LambdaAlarms } from "./lambda-alarms";
|
|
5
|
+
export type { QueueAlarmsProps } from "./queue-alarms";
|
|
6
|
+
export { QueueAlarms } from "./queue-alarms";
|
|
5
7
|
export type { ServiceAlarmsProps } from "./service-alarms";
|
|
6
8
|
export { ServiceAlarms } from "./service-alarms";
|
|
7
9
|
export type { SlackAlarmProps } from "./slack-alarm";
|
package/lib/alarms/index.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
export { DatabaseAlarms } from "./database-alarms";
|
|
2
2
|
export { LambdaAlarms } from "./lambda-alarms";
|
|
3
|
+
export { QueueAlarms } from "./queue-alarms";
|
|
3
4
|
export { ServiceAlarms } from "./service-alarms";
|
|
4
5
|
export { SlackAlarm } from "./slack-alarm";
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWxhcm1zL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUVsRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFFOUMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFBO0FBRTVDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQTtBQUVoRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgeyBEYXRhYmFzZUFsYXJtc1Byb3BzIH0gZnJvbSBcIi4vZGF0YWJhc2UtYWxhcm1zXCJcbmV4cG9ydCB7IERhdGFiYXNlQWxhcm1zIH0gZnJvbSBcIi4vZGF0YWJhc2UtYWxhcm1zXCJcbmV4cG9ydCB0eXBlIHsgTGFtYmRhQWxhcm1zUHJvcHMgfSBmcm9tIFwiLi9sYW1iZGEtYWxhcm1zXCJcbmV4cG9ydCB7IExhbWJkYUFsYXJtcyB9IGZyb20gXCIuL2xhbWJkYS1hbGFybXNcIlxuZXhwb3J0IHR5cGUgeyBRdWV1ZUFsYXJtc1Byb3BzIH0gZnJvbSBcIi4vcXVldWUtYWxhcm1zXCJcbmV4cG9ydCB7IFF1ZXVlQWxhcm1zIH0gZnJvbSBcIi4vcXVldWUtYWxhcm1zXCJcbmV4cG9ydCB0eXBlIHsgU2VydmljZUFsYXJtc1Byb3BzIH0gZnJvbSBcIi4vc2VydmljZS1hbGFybXNcIlxuZXhwb3J0IHsgU2VydmljZUFsYXJtcyB9IGZyb20gXCIuL3NlcnZpY2UtYWxhcm1zXCJcbmV4cG9ydCB0eXBlIHsgU2xhY2tBbGFybVByb3BzIH0gZnJvbSBcIi4vc2xhY2stYWxhcm1cIlxuZXhwb3J0IHsgU2xhY2tBbGFybSB9IGZyb20gXCIuL3NsYWNrLWFsYXJtXCJcbiJdfQ==
|