@rio-cloud/cdk-v2-constructs 2.5.3 → 2.5.6
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/.jsii +97 -11
- package/CHANGELOG.md +6 -0
- package/lib/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring.d.ts +14 -4
- package/lib/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring.js +72 -24
- package/lib/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring.d.ts +4 -0
- package/lib/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring.js +25 -12
- package/package.json +1 -1
- package/version.json +1 -1
package/.jsii
CHANGED
|
@@ -3044,7 +3044,7 @@
|
|
|
3044
3044
|
"assembly": "@rio-cloud/cdk-v2-constructs",
|
|
3045
3045
|
"base": "constructs.Construct",
|
|
3046
3046
|
"docs": {
|
|
3047
|
-
"remarks": "The construct creates
|
|
3047
|
+
"remarks": "The construct creates monitoring for AWS Backup jobs.",
|
|
3048
3048
|
"stability": "stable",
|
|
3049
3049
|
"summary": "This is a beta construct and is likely to have breaking changes."
|
|
3050
3050
|
},
|
|
@@ -3055,7 +3055,7 @@
|
|
|
3055
3055
|
},
|
|
3056
3056
|
"locationInModule": {
|
|
3057
3057
|
"filename": "src/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring.ts",
|
|
3058
|
-
"line":
|
|
3058
|
+
"line": 16
|
|
3059
3059
|
},
|
|
3060
3060
|
"parameters": [
|
|
3061
3061
|
{
|
|
@@ -3069,17 +3069,101 @@
|
|
|
3069
3069
|
"type": {
|
|
3070
3070
|
"primitive": "string"
|
|
3071
3071
|
}
|
|
3072
|
+
},
|
|
3073
|
+
{
|
|
3074
|
+
"name": "props",
|
|
3075
|
+
"type": {
|
|
3076
|
+
"fqn": "@rio-cloud/cdk-v2-constructs.AwsBackupMonitoringProps"
|
|
3077
|
+
}
|
|
3072
3078
|
}
|
|
3073
3079
|
]
|
|
3074
3080
|
},
|
|
3075
3081
|
"kind": "class",
|
|
3076
3082
|
"locationInModule": {
|
|
3077
3083
|
"filename": "src/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring.ts",
|
|
3078
|
-
"line":
|
|
3084
|
+
"line": 15
|
|
3079
3085
|
},
|
|
3080
3086
|
"name": "AwsBackupMonitoring",
|
|
3081
3087
|
"symbolId": "src/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring:AwsBackupMonitoring"
|
|
3082
3088
|
},
|
|
3089
|
+
"@rio-cloud/cdk-v2-constructs.AwsBackupMonitoringProps": {
|
|
3090
|
+
"assembly": "@rio-cloud/cdk-v2-constructs",
|
|
3091
|
+
"datatype": true,
|
|
3092
|
+
"docs": {
|
|
3093
|
+
"stability": "stable"
|
|
3094
|
+
},
|
|
3095
|
+
"fqn": "@rio-cloud/cdk-v2-constructs.AwsBackupMonitoringProps",
|
|
3096
|
+
"kind": "interface",
|
|
3097
|
+
"locationInModule": {
|
|
3098
|
+
"filename": "src/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring.ts",
|
|
3099
|
+
"line": 7
|
|
3100
|
+
},
|
|
3101
|
+
"name": "AwsBackupMonitoringProps",
|
|
3102
|
+
"properties": [
|
|
3103
|
+
{
|
|
3104
|
+
"abstract": true,
|
|
3105
|
+
"docs": {
|
|
3106
|
+
"stability": "stable"
|
|
3107
|
+
},
|
|
3108
|
+
"immutable": true,
|
|
3109
|
+
"locationInModule": {
|
|
3110
|
+
"filename": "src/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring.ts",
|
|
3111
|
+
"line": 8
|
|
3112
|
+
},
|
|
3113
|
+
"name": "serviceName",
|
|
3114
|
+
"type": {
|
|
3115
|
+
"primitive": "string"
|
|
3116
|
+
}
|
|
3117
|
+
}
|
|
3118
|
+
],
|
|
3119
|
+
"symbolId": "src/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring:AwsBackupMonitoringProps"
|
|
3120
|
+
},
|
|
3121
|
+
"@rio-cloud/cdk-v2-constructs.AwsBackupOverallMonitoring": {
|
|
3122
|
+
"assembly": "@rio-cloud/cdk-v2-constructs",
|
|
3123
|
+
"base": "constructs.Construct",
|
|
3124
|
+
"docs": {
|
|
3125
|
+
"remarks": "The construct creates monitoring for all AWS Backup jobs.",
|
|
3126
|
+
"stability": "stable",
|
|
3127
|
+
"summary": "This is a beta construct and is likely to have breaking changes."
|
|
3128
|
+
},
|
|
3129
|
+
"fqn": "@rio-cloud/cdk-v2-constructs.AwsBackupOverallMonitoring",
|
|
3130
|
+
"initializer": {
|
|
3131
|
+
"docs": {
|
|
3132
|
+
"stability": "stable"
|
|
3133
|
+
},
|
|
3134
|
+
"locationInModule": {
|
|
3135
|
+
"filename": "src/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring.ts",
|
|
3136
|
+
"line": 56
|
|
3137
|
+
},
|
|
3138
|
+
"parameters": [
|
|
3139
|
+
{
|
|
3140
|
+
"name": "scope",
|
|
3141
|
+
"type": {
|
|
3142
|
+
"fqn": "constructs.Construct"
|
|
3143
|
+
}
|
|
3144
|
+
},
|
|
3145
|
+
{
|
|
3146
|
+
"name": "id",
|
|
3147
|
+
"type": {
|
|
3148
|
+
"primitive": "string"
|
|
3149
|
+
}
|
|
3150
|
+
},
|
|
3151
|
+
{
|
|
3152
|
+
"name": "props",
|
|
3153
|
+
"type": {
|
|
3154
|
+
"fqn": "@rio-cloud/cdk-v2-constructs.AwsBackupMonitoringProps"
|
|
3155
|
+
}
|
|
3156
|
+
}
|
|
3157
|
+
]
|
|
3158
|
+
},
|
|
3159
|
+
"kind": "class",
|
|
3160
|
+
"locationInModule": {
|
|
3161
|
+
"filename": "src/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring.ts",
|
|
3162
|
+
"line": 55
|
|
3163
|
+
},
|
|
3164
|
+
"name": "AwsBackupOverallMonitoring",
|
|
3165
|
+
"symbolId": "src/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring:AwsBackupOverallMonitoring"
|
|
3166
|
+
},
|
|
3083
3167
|
"@rio-cloud/cdk-v2-constructs.Claidometer": {
|
|
3084
3168
|
"assembly": "@rio-cloud/cdk-v2-constructs",
|
|
3085
3169
|
"base": "constructs.Construct",
|
|
@@ -4096,7 +4180,9 @@
|
|
|
4096
4180
|
"assembly": "@rio-cloud/cdk-v2-constructs",
|
|
4097
4181
|
"base": "constructs.Construct",
|
|
4098
4182
|
"docs": {
|
|
4099
|
-
"
|
|
4183
|
+
"remarks": "The construct creates monitoring (based on anomaly detection) for the usage of the most relevant Datadog resources",
|
|
4184
|
+
"stability": "stable",
|
|
4185
|
+
"summary": "This is a beta construct and is likely to have breaking changes."
|
|
4100
4186
|
},
|
|
4101
4187
|
"fqn": "@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoring",
|
|
4102
4188
|
"initializer": {
|
|
@@ -4105,7 +4191,7 @@
|
|
|
4105
4191
|
},
|
|
4106
4192
|
"locationInModule": {
|
|
4107
4193
|
"filename": "src/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring.ts",
|
|
4108
|
-
"line":
|
|
4194
|
+
"line": 37
|
|
4109
4195
|
},
|
|
4110
4196
|
"parameters": [
|
|
4111
4197
|
{
|
|
@@ -4131,7 +4217,7 @@
|
|
|
4131
4217
|
"kind": "class",
|
|
4132
4218
|
"locationInModule": {
|
|
4133
4219
|
"filename": "src/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring.ts",
|
|
4134
|
-
"line":
|
|
4220
|
+
"line": 36
|
|
4135
4221
|
},
|
|
4136
4222
|
"name": "DatadogUsageMonitoring",
|
|
4137
4223
|
"symbolId": "src/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring:DatadogUsageMonitoring"
|
|
@@ -4146,7 +4232,7 @@
|
|
|
4146
4232
|
"kind": "interface",
|
|
4147
4233
|
"locationInModule": {
|
|
4148
4234
|
"filename": "src/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring.ts",
|
|
4149
|
-
"line":
|
|
4235
|
+
"line": 26
|
|
4150
4236
|
},
|
|
4151
4237
|
"name": "DatadogUsageMonitoringProps",
|
|
4152
4238
|
"properties": [
|
|
@@ -4158,7 +4244,7 @@
|
|
|
4158
4244
|
"immutable": true,
|
|
4159
4245
|
"locationInModule": {
|
|
4160
4246
|
"filename": "src/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring.ts",
|
|
4161
|
-
"line":
|
|
4247
|
+
"line": 28
|
|
4162
4248
|
},
|
|
4163
4249
|
"name": "alertType",
|
|
4164
4250
|
"type": {
|
|
@@ -4173,7 +4259,7 @@
|
|
|
4173
4259
|
"immutable": true,
|
|
4174
4260
|
"locationInModule": {
|
|
4175
4261
|
"filename": "src/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring.ts",
|
|
4176
|
-
"line":
|
|
4262
|
+
"line": 29
|
|
4177
4263
|
},
|
|
4178
4264
|
"name": "organization",
|
|
4179
4265
|
"type": {
|
|
@@ -4188,7 +4274,7 @@
|
|
|
4188
4274
|
"immutable": true,
|
|
4189
4275
|
"locationInModule": {
|
|
4190
4276
|
"filename": "src/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring.ts",
|
|
4191
|
-
"line":
|
|
4277
|
+
"line": 27
|
|
4192
4278
|
},
|
|
4193
4279
|
"name": "serviceName",
|
|
4194
4280
|
"type": {
|
|
@@ -8361,5 +8447,5 @@
|
|
|
8361
8447
|
}
|
|
8362
8448
|
},
|
|
8363
8449
|
"version": "0.0.0",
|
|
8364
|
-
"fingerprint": "
|
|
8450
|
+
"fingerprint": "OIkW1e+znFP7aRfsj3BMjhlsdgTx8lf1pc1HNxRZeq8="
|
|
8365
8451
|
}
|
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,12 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
4
|
|
|
5
|
+
### [2.5.6](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv2.5.5&sourceBranch=refs%2Ftags%2Fv2.5.6) (2022-08-02)
|
|
6
|
+
|
|
7
|
+
### [2.5.5](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv2.5.4&sourceBranch=refs%2Ftags%2Fv2.5.5) (2022-07-29)
|
|
8
|
+
|
|
9
|
+
### [2.5.4](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv2.5.3&sourceBranch=refs%2Ftags%2Fv2.5.4) (2022-07-28)
|
|
10
|
+
|
|
5
11
|
### [2.5.3](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv2.5.2&sourceBranch=refs%2Ftags%2Fv2.5.3) (2022-07-28)
|
|
6
12
|
|
|
7
13
|
### [2.5.2](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv2.5.1&sourceBranch=refs%2Ftags%2Fv2.5.2) (2022-07-28)
|
|
@@ -1,8 +1,18 @@
|
|
|
1
|
-
import
|
|
1
|
+
import * as constructs from 'constructs';
|
|
2
|
+
export interface AwsBackupMonitoringProps {
|
|
3
|
+
readonly serviceName: string;
|
|
4
|
+
}
|
|
5
|
+
/**
|
|
6
|
+
* This is a beta construct and is likely to have breaking changes.
|
|
7
|
+
* The construct creates monitoring for AWS Backup jobs.
|
|
8
|
+
*/
|
|
9
|
+
export declare class AwsBackupMonitoring extends constructs.Construct {
|
|
10
|
+
constructor(scope: constructs.Construct, id: string, props: AwsBackupMonitoringProps);
|
|
11
|
+
}
|
|
2
12
|
/**
|
|
3
13
|
* This is a beta construct and is likely to have breaking changes.
|
|
4
|
-
* The construct creates
|
|
14
|
+
* The construct creates monitoring for all AWS Backup jobs.
|
|
5
15
|
*/
|
|
6
|
-
export declare class
|
|
7
|
-
constructor(scope: Construct, id: string);
|
|
16
|
+
export declare class AwsBackupOverallMonitoring extends constructs.Construct {
|
|
17
|
+
constructor(scope: constructs.Construct, id: string, props: AwsBackupMonitoringProps);
|
|
8
18
|
}
|
|
@@ -1,48 +1,96 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var _a;
|
|
2
|
+
var _a, _b;
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.AwsBackupMonitoring = void 0;
|
|
4
|
+
exports.AwsBackupOverallMonitoring = exports.AwsBackupMonitoring = void 0;
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
6
|
const path = require("path");
|
|
7
|
-
const
|
|
8
|
-
const
|
|
7
|
+
const cdk = require("aws-cdk-lib");
|
|
8
|
+
const ssm = require("aws-cdk-lib/aws-ssm");
|
|
9
|
+
const constructs = require("constructs");
|
|
9
10
|
const rio_claidometer_1 = require("../../../rio-claidometer");
|
|
10
11
|
/**
|
|
11
12
|
* This is a beta construct and is likely to have breaking changes.
|
|
12
|
-
* The construct creates
|
|
13
|
+
* The construct creates monitoring for AWS Backup jobs.
|
|
13
14
|
*/
|
|
14
|
-
class AwsBackupMonitoring extends
|
|
15
|
-
constructor(scope, id) {
|
|
15
|
+
class AwsBackupMonitoring extends constructs.Construct {
|
|
16
|
+
constructor(scope, id, props) {
|
|
16
17
|
super(scope, id);
|
|
17
|
-
const teamName =
|
|
18
|
-
|
|
18
|
+
const teamName = ssm.StringParameter.fromStringParameterName(this, 'TeamName', '/config/team/name').stringValue;
|
|
19
|
+
const commonTags = [
|
|
20
|
+
`service:${props.serviceName}`,
|
|
21
|
+
`team:${teamName}`,
|
|
22
|
+
];
|
|
23
|
+
new cdk.CfnResource(this, 'BackupMonitoringCopyJobs', {
|
|
19
24
|
type: 'Datadog::Monitors::Monitor',
|
|
20
25
|
properties: {
|
|
21
|
-
Name:
|
|
26
|
+
Name: 'AWS Backup Copy Job to central account failed',
|
|
22
27
|
Type: 'query alert',
|
|
23
|
-
Query: `sum(last_1d):sum:aws.backup.number_of_copy_jobs_failed{account_id:${
|
|
24
|
-
Message: `AWS Backup Copy job to central backup account has failed @opsgenie-${teamName}.\nCheck the job under AWS Backup -> Jobs -> Copy Jobs`,
|
|
28
|
+
Query: `sum(last_1d):sum:aws.backup.number_of_copy_jobs_failed{account_id:${cdk.Stack.of(this).account}}.as_count() > 0`,
|
|
29
|
+
Message: `[P4] AWS Backup Copy job to central backup account has failed @opsgenie-${teamName}.\nCheck the job under AWS Backup -> Jobs -> Copy Jobs`,
|
|
30
|
+
Tags: commonTags,
|
|
25
31
|
},
|
|
26
32
|
});
|
|
27
|
-
new
|
|
33
|
+
new cdk.CfnResource(this, 'BackupMonitoringJob', {
|
|
28
34
|
type: 'Datadog::Monitors::Monitor',
|
|
29
35
|
properties: {
|
|
30
|
-
Name:
|
|
36
|
+
Name: 'AWS Backup Job Monitor',
|
|
31
37
|
Type: 'query alert',
|
|
32
|
-
Query: `sum(last_1d):sum:aws.backup.number_of_backup_jobs_failed{account_id:${
|
|
33
|
-
Message: `AWS Backup job has failed @opsgenie-${teamName}.\nCheck the job under AWS Backup -> Jobs -> Backup Jobs`,
|
|
38
|
+
Query: `sum(last_1d):sum:aws.backup.number_of_backup_jobs_failed{account_id:${cdk.Stack.of(this).account}}.as_count() > 0`,
|
|
39
|
+
Message: `[P4] AWS Backup job has failed @opsgenie-${teamName}.\nCheck the job under AWS Backup -> Jobs -> Backup Jobs`,
|
|
40
|
+
Tags: commonTags,
|
|
34
41
|
},
|
|
35
42
|
});
|
|
36
|
-
|
|
37
|
-
new rio_claidometer_1.Claidometer(this, 'Claidometer', {
|
|
38
|
-
product: rio_claidometer_1.ClaidometerProduct.CDK_CONTRIBUTION,
|
|
39
|
-
packageName,
|
|
40
|
-
feature,
|
|
41
|
-
version: '0.0.4',
|
|
42
|
-
});
|
|
43
|
+
addClaidometer(this);
|
|
43
44
|
}
|
|
44
45
|
}
|
|
45
46
|
exports.AwsBackupMonitoring = AwsBackupMonitoring;
|
|
46
47
|
_a = JSII_RTTI_SYMBOL_1;
|
|
47
48
|
AwsBackupMonitoring[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.AwsBackupMonitoring", version: "0.0.0" };
|
|
48
|
-
|
|
49
|
+
/**
|
|
50
|
+
* This is a beta construct and is likely to have breaking changes.
|
|
51
|
+
* The construct creates monitoring for all AWS Backup jobs.
|
|
52
|
+
*/
|
|
53
|
+
class AwsBackupOverallMonitoring extends constructs.Construct {
|
|
54
|
+
constructor(scope, id, props) {
|
|
55
|
+
super(scope, id);
|
|
56
|
+
const teamName = ssm.StringParameter.fromStringParameterName(this, 'TeamName', '/config/team/name').stringValue;
|
|
57
|
+
const commonTags = [
|
|
58
|
+
`service:${props.serviceName}`,
|
|
59
|
+
`team:${teamName}`,
|
|
60
|
+
];
|
|
61
|
+
new cdk.CfnResource(this, 'OverallBackupMonitoringCopyJobs', {
|
|
62
|
+
type: 'Datadog::Monitors::Monitor',
|
|
63
|
+
properties: {
|
|
64
|
+
Name: 'AWS Backup overall Copy Job to central account failed',
|
|
65
|
+
Type: 'query alert',
|
|
66
|
+
Query: 'sum(last_1d):sum:aws.backup.number_of_copy_jobs_failed{*} by {account_name}.as_count() > 0',
|
|
67
|
+
Message: `[P4] AWS Backup Copy job to central backup account has failed @opsgenie-${teamName}.\nCheck the job under AWS Backup -> Jobs -> Copy Jobs`,
|
|
68
|
+
Tags: commonTags,
|
|
69
|
+
},
|
|
70
|
+
});
|
|
71
|
+
new cdk.CfnResource(this, 'OverallBackupMonitoringJob', {
|
|
72
|
+
type: 'Datadog::Monitors::Monitor',
|
|
73
|
+
properties: {
|
|
74
|
+
Name: 'AWS Backup overall Job error',
|
|
75
|
+
Type: 'query alert',
|
|
76
|
+
Query: 'sum(last_1d):sum:aws.backup.number_of_backup_jobs_failed{*} by {account_name}.as_count() > 0',
|
|
77
|
+
Message: `[P4] AWS Backup job has failed @opsgenie-${teamName}.\nCheck the job under AWS Backup -> Jobs -> Backup Jobs`,
|
|
78
|
+
Tags: commonTags,
|
|
79
|
+
},
|
|
80
|
+
});
|
|
81
|
+
addClaidometer(this);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
exports.AwsBackupOverallMonitoring = AwsBackupOverallMonitoring;
|
|
85
|
+
_b = JSII_RTTI_SYMBOL_1;
|
|
86
|
+
AwsBackupOverallMonitoring[_b] = { fqn: "@rio-cloud/cdk-v2-constructs.AwsBackupOverallMonitoring", version: "0.0.0" };
|
|
87
|
+
function addClaidometer(scope) {
|
|
88
|
+
const [feature, packageName] = __dirname.split(path.sep).reverse();
|
|
89
|
+
new rio_claidometer_1.Claidometer(scope, 'Claidometer', {
|
|
90
|
+
product: rio_claidometer_1.ClaidometerProduct.CDK_CONTRIBUTION,
|
|
91
|
+
packageName,
|
|
92
|
+
feature,
|
|
93
|
+
version: '0.0.3',
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-backup-monitoring.js","sourceRoot":"","sources":["../../../../src/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport * as constructs from 'constructs';\nimport { Claidometer, ClaidometerProduct } from '../../../rio-claidometer';\n\nexport interface AwsBackupMonitoringProps {\n  readonly serviceName: string;\n}\n\n/**\n * This is a beta construct and is likely to have breaking changes.\n * The construct creates monitoring for AWS Backup jobs.\n */\nexport class AwsBackupMonitoring extends constructs.Construct {\n  constructor(scope: constructs.Construct, id: string, props: AwsBackupMonitoringProps) {\n    super(scope, id);\n\n    const teamName = ssm.StringParameter.fromStringParameterName(this, 'TeamName', '/config/team/name').stringValue;\n    const commonTags = [\n      `service:${props.serviceName}`,\n      `team:${teamName}`,\n    ];\n\n    new cdk.CfnResource(this, 'BackupMonitoringCopyJobs', {\n      type: 'Datadog::Monitors::Monitor',\n      properties: {\n        Name: 'AWS Backup Copy Job to central account failed',\n        Type: 'query alert',\n        Query: `sum(last_1d):sum:aws.backup.number_of_copy_jobs_failed{account_id:${cdk.Stack.of(this).account}}.as_count() > 0`,\n        Message: `[P4] AWS Backup Copy job to central backup account has failed @opsgenie-${teamName}.\\nCheck the job under AWS Backup -> Jobs -> Copy Jobs`,\n        Tags: commonTags,\n      },\n    });\n\n    new cdk.CfnResource(this, 'BackupMonitoringJob', {\n      type: 'Datadog::Monitors::Monitor',\n      properties: {\n        Name: 'AWS Backup Job Monitor',\n        Type: 'query alert',\n        Query: `sum(last_1d):sum:aws.backup.number_of_backup_jobs_failed{account_id:${cdk.Stack.of(this).account}}.as_count() > 0`,\n        Message: `[P4] AWS Backup job has failed @opsgenie-${teamName}.\\nCheck the job under AWS Backup -> Jobs -> Backup Jobs`,\n        Tags: commonTags,\n      },\n    });\n\n    addClaidometer(this);\n  }\n}\n\n/**\n * This is a beta construct and is likely to have breaking changes.\n * The construct creates monitoring for all AWS Backup jobs.\n */\nexport class AwsBackupOverallMonitoring extends constructs.Construct {\n  constructor(scope: constructs.Construct, id: string, props: AwsBackupMonitoringProps) {\n    super(scope, id);\n\n    const teamName = ssm.StringParameter.fromStringParameterName(this, 'TeamName', '/config/team/name').stringValue;\n    const commonTags = [\n      `service:${props.serviceName}`,\n      `team:${teamName}`,\n    ];\n\n    new cdk.CfnResource(this, 'OverallBackupMonitoringCopyJobs', {\n      type: 'Datadog::Monitors::Monitor',\n      properties: {\n        Name: 'AWS Backup overall Copy Job to central account failed',\n        Type: 'query alert',\n        Query: 'sum(last_1d):sum:aws.backup.number_of_copy_jobs_failed{*} by {account_name}.as_count() > 0',\n        Message: `[P4] AWS Backup Copy job to central backup account has failed @opsgenie-${teamName}.\\nCheck the job under AWS Backup -> Jobs -> Copy Jobs`,\n        Tags: commonTags,\n      },\n    });\n\n    new cdk.CfnResource(this, 'OverallBackupMonitoringJob', {\n      type: 'Datadog::Monitors::Monitor',\n      properties: {\n        Name: 'AWS Backup overall Job error',\n        Type: 'query alert',\n        Query: 'sum(last_1d):sum:aws.backup.number_of_backup_jobs_failed{*} by {account_name}.as_count() > 0',\n        Message: `[P4] AWS Backup job has failed @opsgenie-${teamName}.\\nCheck the job under AWS Backup -> Jobs -> Backup Jobs`,\n        Tags: commonTags,\n      },\n    });\n\n    addClaidometer(this);\n  }\n}\n\nfunction addClaidometer(scope: constructs.Construct) {\n  const [feature, packageName] = __dirname.split(path.sep).reverse();\n  new Claidometer(scope, 'Claidometer', {\n    product: ClaidometerProduct.CDK_CONTRIBUTION,\n    packageName,\n    feature,\n    version: '0.0.3',\n  });\n}\n"]}
|
|
@@ -6,6 +6,10 @@ export interface DatadogUsageMonitoringProps {
|
|
|
6
6
|
readonly alertType: DatadogAlertType;
|
|
7
7
|
readonly organization: DatadogOrganization;
|
|
8
8
|
}
|
|
9
|
+
/**
|
|
10
|
+
* This is a beta construct and is likely to have breaking changes.
|
|
11
|
+
* The construct creates monitoring (based on anomaly detection) for the usage of the most relevant Datadog resources
|
|
12
|
+
*/
|
|
9
13
|
export declare class DatadogUsageMonitoring extends constructs.Construct {
|
|
10
14
|
constructor(scope: constructs.Construct, id: string, props: DatadogUsageMonitoringProps);
|
|
11
15
|
private createAnomalyMonitorForSpikes;
|
|
@@ -4,6 +4,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
4
4
|
exports.DatadogUsageMonitoring = void 0;
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
6
|
const path = require("path");
|
|
7
|
+
const ssm = require("aws-cdk-lib/aws-ssm");
|
|
7
8
|
const constructs = require("constructs");
|
|
8
9
|
const datadogMonitor_1 = require("../../../datadog/datadogMonitor");
|
|
9
10
|
const rio_claidometer_1 = require("../../../rio-claidometer");
|
|
@@ -17,9 +18,14 @@ function getOrganizationUrlPrefix(organization) {
|
|
|
17
18
|
return 'rio-landingzone';
|
|
18
19
|
}
|
|
19
20
|
}
|
|
21
|
+
/**
|
|
22
|
+
* This is a beta construct and is likely to have breaking changes.
|
|
23
|
+
* The construct creates monitoring (based on anomaly detection) for the usage of the most relevant Datadog resources
|
|
24
|
+
*/
|
|
20
25
|
class DatadogUsageMonitoring extends constructs.Construct {
|
|
21
26
|
constructor(scope, id, props) {
|
|
22
27
|
super(scope, id);
|
|
28
|
+
const teamName = ssm.StringParameter.fromStringParameterName(this, 'TeamName', '/config/team/name').stringValue;
|
|
23
29
|
const infrastructureUsageSpikeMonitors = [
|
|
24
30
|
{
|
|
25
31
|
humanReadableName: 'infrastructure hosts',
|
|
@@ -110,17 +116,11 @@ class DatadogUsageMonitoring extends constructs.Construct {
|
|
|
110
116
|
},
|
|
111
117
|
];
|
|
112
118
|
for (const usageSpikeMonitor of [].concat(infrastructureUsageSpikeMonitors, logManagementUsageSpikeMonitors, apmUsageSpikeMonitors, serverlessUsageSpikeMonitors, syntheticUsageSpikeMonitors)) {
|
|
113
|
-
this.createAnomalyMonitorForSpikes(props.serviceName, props.alertType, usageSpikeMonitor);
|
|
119
|
+
this.createAnomalyMonitorForSpikes(props.serviceName, teamName, props.alertType, usageSpikeMonitor);
|
|
114
120
|
}
|
|
115
|
-
|
|
116
|
-
new rio_claidometer_1.Claidometer(this, 'Claidometer', {
|
|
117
|
-
product: rio_claidometer_1.ClaidometerProduct.CDK_CONTRIBUTION,
|
|
118
|
-
packageName,
|
|
119
|
-
feature,
|
|
120
|
-
version: '0.0.4',
|
|
121
|
-
});
|
|
121
|
+
addClaidometer(this);
|
|
122
122
|
}
|
|
123
|
-
createAnomalyMonitorForSpikes(serviceName, alertType, usageSpikeMonitor) {
|
|
123
|
+
createAnomalyMonitorForSpikes(serviceName, teamName, alertType, usageSpikeMonitor) {
|
|
124
124
|
var _b;
|
|
125
125
|
return new datadogMonitor_1.DatadogMonitor(this, usageSpikeMonitor.humanReadableName, {
|
|
126
126
|
serviceName,
|
|
@@ -129,15 +129,19 @@ class DatadogUsageMonitoring extends constructs.Construct {
|
|
|
129
129
|
name: `${usageSpikeMonitor.humanReadableName} spike`,
|
|
130
130
|
type: 'query alert',
|
|
131
131
|
query: `avg(last_12h):anomalies(${usageSpikeMonitor.query}, 'agile', 3, direction='above', interval=120, alert_window='last_30m', seasonality='weekly', timezone='europe/berlin', count_default_zero='true') >= 1`,
|
|
132
|
-
message:
|
|
132
|
+
message: `[P4] ${usageSpikeMonitor.humanReadableName} are getting out-of-control. ${(_b = usageSpikeMonitor.additionalMessage) !== null && _b !== void 0 ? _b : ''}`,
|
|
133
133
|
options: {
|
|
134
134
|
include_tags: false,
|
|
135
135
|
notify_no_data: false,
|
|
136
136
|
threshold_windows: {
|
|
137
|
-
trigger_window: '
|
|
137
|
+
trigger_window: 'last_30m',
|
|
138
138
|
recovery_window: 'last_15m',
|
|
139
139
|
},
|
|
140
140
|
},
|
|
141
|
+
tags: [
|
|
142
|
+
`service:${serviceName}`,
|
|
143
|
+
`team:${teamName}`,
|
|
144
|
+
],
|
|
141
145
|
},
|
|
142
146
|
});
|
|
143
147
|
}
|
|
@@ -145,4 +149,13 @@ class DatadogUsageMonitoring extends constructs.Construct {
|
|
|
145
149
|
exports.DatadogUsageMonitoring = DatadogUsageMonitoring;
|
|
146
150
|
_a = JSII_RTTI_SYMBOL_1;
|
|
147
151
|
DatadogUsageMonitoring[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoring", version: "0.0.0" };
|
|
148
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-usage-monitoring.js","sourceRoot":"","sources":["../../../../src/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as constructs from 'constructs';\nimport { DatadogAlertType, DatadogMonitor } from '../../../datadog/datadogMonitor';\nimport { Claidometer, ClaidometerProduct } from '../../../rio-claidometer';\n\nexport type DatadogOrganization = 'EU' | 'LATAM' | 'Landing Zone';\n\nfunction getOrganizationUrlPrefix(organization: DatadogOrganization): string {\n  switch (organization) {\n    case 'EU':\n      return 'app';\n    case 'LATAM':\n      return 'rio-brazil';\n    case 'Landing Zone':\n      return 'rio-landingzone';\n  }\n}\n\ninterface UsageSpikeMonitor {\n  humanReadableName: string;\n  query: string;\n  additionalMessage?: string;\n}\n\nexport interface DatadogUsageMonitoringProps {\n  readonly serviceName: string;\n  readonly alertType: DatadogAlertType;\n  readonly organization: DatadogOrganization;\n}\n\nexport class DatadogUsageMonitoring extends constructs.Construct {\n  constructor(scope: constructs.Construct, id: string, props: DatadogUsageMonitoringProps) {\n    super(scope, id);\n\n    const infrastructureUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'infrastructure hosts',\n        query: 'sum:datadog.estimated_usage.hosts{*}',\n      },\n      {\n        humanReadableName: \"infrastructure hosts for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.hosts{*} by {child_org_name}',\n      },\n      { humanReadableName: 'Fargate tasks', query: 'sum:datadog.apm.fargate_task_instance{*}' },\n      { humanReadableName: 'profiled Fargate tasks', query: 'sum:datadog.profiling.fargate{*}' },\n      {\n        humanReadableName: 'custom metrics',\n        query: 'sum:datadog.estimated_usage.metrics.custom{*}',\n      },\n      {\n        humanReadableName: \"custom metrics for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.metrics.custom{*} by {child_org_name}',\n      },\n    ];\n\n    const additionalMessageLogManagementForGloballyScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/465/log-management-estimated-usage for more details.`;\n    const additionalMessageLogManagementForLogIndexScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/465/log-management-estimated-usage?tpl_var_datadog_index={{datadog_index.name}} for more details.`;\n    const logManagementUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'log ingestion',\n        query: 'sum:datadog.estimated_usage.logs.ingested_bytes{*}.as_count()',\n        additionalMessage: additionalMessageLogManagementForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: \"log ingestion for '{{datadog_index.name}}'\",\n        query: 'sum:datadog.estimated_usage.logs.ingested_bytes{*} by {datadog_index}.as_count()',\n        additionalMessage: additionalMessageLogManagementForLogIndexScopedMonitors,\n      },\n      {\n        humanReadableName: 'log indexing',\n        query: 'sum:datadog.estimated_usage.logs.ingested_events{datadog_is_excluded:false}.as_count()',\n        additionalMessage: additionalMessageLogManagementForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: \"log indexing for '{{datadog_index.name}}'\",\n        query: 'sum:datadog.estimated_usage.logs.ingested_events{datadog_is_excluded:false} by {datadog_index}.as_count()',\n        additionalMessage: additionalMessageLogManagementForLogIndexScopedMonitors,\n      },\n    ];\n\n    const additionalMessageApmForGloballyScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/489/apm-traces-estimated-usage for more details.`;\n    const additionalMessageApmForEnvScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/489/apm-traces-estimated-usage?tpl_var_env={{env.name}} for more details.`;\n    const apmUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      { humanReadableName: 'APM hosts', query: 'sum:datadog.estimated_usage.apm_hosts{*}' },\n      {\n        humanReadableName: \"APM hosts for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.apm_hosts{*} by {child_org_name}',\n        additionalMessage: additionalMessageApmForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: 'span ingestion',\n        query: 'sum:datadog.estimated_usage.apm.ingested_bytes{*}.as_count()',\n      },\n      {\n        humanReadableName: \"span ingestion for '{{env.name}}'\",\n        query: 'sum:datadog.estimated_usage.apm.ingested_bytes{*} by {env}.as_count()',\n        additionalMessage: additionalMessageApmForEnvScopedMonitors,\n      },\n      {\n        humanReadableName: 'span indexing',\n        query: 'sum:datadog.estimated_usage.apm.indexed_spans{*}.as_count()',\n        additionalMessage: additionalMessageApmForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: \"span indexing for '{{env.name}}'\",\n        query: 'sum:datadog.estimated_usage.apm.indexed_spans{*} by {env}.as_count()',\n        additionalMessage: additionalMessageApmForEnvScopedMonitors,\n      },\n    ];\n\n    const syntheticUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'Synthetic API tests',\n        query: 'sum:datadog.estimated_usage.synthetics.api_test_runs{*}.as_count()',\n      },\n    ];\n\n    const serverlessUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'serverless functions',\n        query: 'sum:datadog.estimated_usage.serverless.aws_lambda_functions{*}',\n      },\n      {\n        humanReadableName: \"serverless functions for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.serverless.aws_lambda_functions{*} by {child_org_name}',\n      },\n    ];\n\n    for (const usageSpikeMonitor of ([] as UsageSpikeMonitor[]).concat(\n      infrastructureUsageSpikeMonitors,\n      logManagementUsageSpikeMonitors,\n      apmUsageSpikeMonitors,\n      serverlessUsageSpikeMonitors,\n      syntheticUsageSpikeMonitors,\n    )) {\n      this.createAnomalyMonitorForSpikes(props.serviceName, props.alertType, usageSpikeMonitor);\n    }\n\n    const [feature, packageName] = __dirname.split(path.sep).reverse();\n    new Claidometer(this, 'Claidometer', {\n      product: ClaidometerProduct.CDK_CONTRIBUTION,\n      packageName,\n      feature,\n      version: '0.0.4',\n    });\n  }\n\n  private createAnomalyMonitorForSpikes(\n    serviceName: string,\n    alertType: DatadogAlertType,\n    usageSpikeMonitor: UsageSpikeMonitor,\n  ): DatadogMonitor {\n    return new DatadogMonitor(this, usageSpikeMonitor.humanReadableName, {\n      serviceName,\n      alertTypes: [alertType],\n      monitor: {\n        name: `${usageSpikeMonitor.humanReadableName} spike`,\n        type: 'query alert',\n        query: `avg(last_12h):anomalies(${usageSpikeMonitor.query}, 'agile', 3, direction='above', interval=120, alert_window='last_30m', seasonality='weekly', timezone='europe/berlin', count_default_zero='true') >= 1`,\n        message: `${usageSpikeMonitor.humanReadableName} are getting out-of-control. ${\n          usageSpikeMonitor.additionalMessage ?? ''\n        }`,\n        options: {\n          include_tags: false,\n          notify_no_data: false,\n          threshold_windows: {\n            trigger_window: 'last_15m',\n            recovery_window: 'last_15m',\n          },\n        },\n      },\n    });\n  }\n}\n"]}
|
|
152
|
+
function addClaidometer(scope) {
|
|
153
|
+
const [feature, packageName] = __dirname.split(path.sep).reverse();
|
|
154
|
+
new rio_claidometer_1.Claidometer(scope, 'Claidometer', {
|
|
155
|
+
product: rio_claidometer_1.ClaidometerProduct.CDK_CONTRIBUTION,
|
|
156
|
+
packageName,
|
|
157
|
+
feature,
|
|
158
|
+
version: '0.0.7',
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-usage-monitoring.js","sourceRoot":"","sources":["../../../../src/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport * as constructs from 'constructs';\nimport { DatadogAlertType, DatadogMonitor } from '../../../datadog/datadogMonitor';\nimport { Claidometer, ClaidometerProduct } from '../../../rio-claidometer';\n\nexport type DatadogOrganization = 'EU' | 'LATAM' | 'Landing Zone';\n\nfunction getOrganizationUrlPrefix(organization: DatadogOrganization): string {\n  switch (organization) {\n    case 'EU':\n      return 'app';\n    case 'LATAM':\n      return 'rio-brazil';\n    case 'Landing Zone':\n      return 'rio-landingzone';\n  }\n}\n\ninterface UsageSpikeMonitor {\n  humanReadableName: string;\n  query: string;\n  additionalMessage?: string;\n}\n\nexport interface DatadogUsageMonitoringProps {\n  readonly serviceName: string;\n  readonly alertType: DatadogAlertType;\n  readonly organization: DatadogOrganization;\n}\n\n/**\n * This is a beta construct and is likely to have breaking changes.\n * The construct creates monitoring (based on anomaly detection) for the usage of the most relevant Datadog resources\n */\nexport class DatadogUsageMonitoring extends constructs.Construct {\n  constructor(scope: constructs.Construct, id: string, props: DatadogUsageMonitoringProps) {\n    super(scope, id);\n\n    const teamName = ssm.StringParameter.fromStringParameterName(this, 'TeamName', '/config/team/name').stringValue;\n\n    const infrastructureUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'infrastructure hosts',\n        query: 'sum:datadog.estimated_usage.hosts{*}',\n      },\n      {\n        humanReadableName: \"infrastructure hosts for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.hosts{*} by {child_org_name}',\n      },\n      { humanReadableName: 'Fargate tasks', query: 'sum:datadog.apm.fargate_task_instance{*}' },\n      { humanReadableName: 'profiled Fargate tasks', query: 'sum:datadog.profiling.fargate{*}' },\n      {\n        humanReadableName: 'custom metrics',\n        query: 'sum:datadog.estimated_usage.metrics.custom{*}',\n      },\n      {\n        humanReadableName: \"custom metrics for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.metrics.custom{*} by {child_org_name}',\n      },\n    ];\n\n    const additionalMessageLogManagementForGloballyScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/465/log-management-estimated-usage for more details.`;\n    const additionalMessageLogManagementForLogIndexScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/465/log-management-estimated-usage?tpl_var_datadog_index={{datadog_index.name}} for more details.`;\n    const logManagementUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'log ingestion',\n        query: 'sum:datadog.estimated_usage.logs.ingested_bytes{*}.as_count()',\n        additionalMessage: additionalMessageLogManagementForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: \"log ingestion for '{{datadog_index.name}}'\",\n        query: 'sum:datadog.estimated_usage.logs.ingested_bytes{*} by {datadog_index}.as_count()',\n        additionalMessage: additionalMessageLogManagementForLogIndexScopedMonitors,\n      },\n      {\n        humanReadableName: 'log indexing',\n        query: 'sum:datadog.estimated_usage.logs.ingested_events{datadog_is_excluded:false}.as_count()',\n        additionalMessage: additionalMessageLogManagementForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: \"log indexing for '{{datadog_index.name}}'\",\n        query: 'sum:datadog.estimated_usage.logs.ingested_events{datadog_is_excluded:false} by {datadog_index}.as_count()',\n        additionalMessage: additionalMessageLogManagementForLogIndexScopedMonitors,\n      },\n    ];\n\n    const additionalMessageApmForGloballyScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/489/apm-traces-estimated-usage for more details.`;\n    const additionalMessageApmForEnvScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/489/apm-traces-estimated-usage?tpl_var_env={{env.name}} for more details.`;\n    const apmUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      { humanReadableName: 'APM hosts', query: 'sum:datadog.estimated_usage.apm_hosts{*}' },\n      {\n        humanReadableName: \"APM hosts for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.apm_hosts{*} by {child_org_name}',\n        additionalMessage: additionalMessageApmForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: 'span ingestion',\n        query: 'sum:datadog.estimated_usage.apm.ingested_bytes{*}.as_count()',\n      },\n      {\n        humanReadableName: \"span ingestion for '{{env.name}}'\",\n        query: 'sum:datadog.estimated_usage.apm.ingested_bytes{*} by {env}.as_count()',\n        additionalMessage: additionalMessageApmForEnvScopedMonitors,\n      },\n      {\n        humanReadableName: 'span indexing',\n        query: 'sum:datadog.estimated_usage.apm.indexed_spans{*}.as_count()',\n        additionalMessage: additionalMessageApmForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: \"span indexing for '{{env.name}}'\",\n        query: 'sum:datadog.estimated_usage.apm.indexed_spans{*} by {env}.as_count()',\n        additionalMessage: additionalMessageApmForEnvScopedMonitors,\n      },\n    ];\n\n    const syntheticUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'Synthetic API tests',\n        query: 'sum:datadog.estimated_usage.synthetics.api_test_runs{*}.as_count()',\n      },\n    ];\n\n    const serverlessUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'serverless functions',\n        query: 'sum:datadog.estimated_usage.serverless.aws_lambda_functions{*}',\n      },\n      {\n        humanReadableName: \"serverless functions for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.serverless.aws_lambda_functions{*} by {child_org_name}',\n      },\n    ];\n\n    for (const usageSpikeMonitor of ([] as UsageSpikeMonitor[]).concat(\n      infrastructureUsageSpikeMonitors,\n      logManagementUsageSpikeMonitors,\n      apmUsageSpikeMonitors,\n      serverlessUsageSpikeMonitors,\n      syntheticUsageSpikeMonitors,\n    )) {\n      this.createAnomalyMonitorForSpikes(props.serviceName, teamName, props.alertType, usageSpikeMonitor);\n    }\n\n    addClaidometer(this);\n  }\n\n  private createAnomalyMonitorForSpikes(\n    serviceName: string,\n    teamName: string,\n    alertType: DatadogAlertType,\n    usageSpikeMonitor: UsageSpikeMonitor,\n  ): DatadogMonitor {\n    return new DatadogMonitor(this, usageSpikeMonitor.humanReadableName, {\n      serviceName,\n      alertTypes: [alertType],\n      monitor: {\n        name: `${usageSpikeMonitor.humanReadableName} spike`,\n        type: 'query alert',\n        query: `avg(last_12h):anomalies(${usageSpikeMonitor.query}, 'agile', 3, direction='above', interval=120, alert_window='last_30m', seasonality='weekly', timezone='europe/berlin', count_default_zero='true') >= 1`,\n        message: `[P4] ${usageSpikeMonitor.humanReadableName} are getting out-of-control. ${\n          usageSpikeMonitor.additionalMessage ?? ''\n        }`,\n        options: {\n          include_tags: false,\n          notify_no_data: false,\n          threshold_windows: {\n            trigger_window: 'last_30m',\n            recovery_window: 'last_15m',\n          },\n        },\n        tags: [\n          `service:${serviceName}`,\n          `team:${teamName}`,\n        ],\n      },\n    });\n  }\n}\n\nfunction addClaidometer(scope: constructs.Construct) {\n  const [feature, packageName] = __dirname.split(path.sep).reverse();\n  new Claidometer(scope, 'Claidometer', {\n    product: ClaidometerProduct.CDK_CONTRIBUTION,\n    packageName,\n    feature,\n    version: '0.0.7',\n  });\n}\n"]}
|
package/package.json
CHANGED
package/version.json
CHANGED