From 891e8d31b5800ab9f3df332bc69c7c169ff01517 Mon Sep 17 00:00:00 2001 From: Patryk Gudalewicz Date: Wed, 1 Mar 2023 18:48:32 +0100 Subject: [PATCH 1/6] "Migrating from Monaco to Terraform for management zone: CD_XCC" --- CN_PREPROD/alerting/cd_xcc_int.tf | 38 ++++ CN_PREPROD/dashboard/cd_xcc_int.tf | 294 +++++++++++++++++++++++++++ CN_PREPROD/dashboard/cd_xcc_test.tf | 294 +++++++++++++++++++++++++++ CN_PREPROD/management_zone/cd_xcc.tf | 52 +++++ 4 files changed, 678 insertions(+) create mode 100644 CN_PREPROD/alerting/cd_xcc_int.tf create mode 100644 CN_PREPROD/dashboard/cd_xcc_int.tf create mode 100644 CN_PREPROD/dashboard/cd_xcc_test.tf create mode 100644 CN_PREPROD/management_zone/cd_xcc.tf diff --git a/CN_PREPROD/alerting/cd_xcc_int.tf b/CN_PREPROD/alerting/cd_xcc_int.tf new file mode 100644 index 00000000..24ddef0f --- /dev/null +++ b/CN_PREPROD/alerting/cd_xcc_int.tf @@ -0,0 +1,38 @@ +# DEFINE dynatrace_alerting.CD_XCC_INT.id = vu9U3hXa3q0AAAABABhidWlsdGluOmFsZXJ0aW5nLnByb2ZpbGUABnRlbmFudAAGdGVuYW50ACQ5ZmQwOGQ5My0xN2JhLTM1M2YtYWRiNC0wMTQ4NWExZDFkZTm-71TeFdrerQ +data "dynatrace_management_zone" "CD_XCC_INT"{ name="CD_XCC" } +resource "dynatrace_alerting" "CD_XCC_INT" { + name = "CD_XCC INT" + management_zone = data.dynatrace_management_zone.CD_XCC_INT.id + rules { + rule { + delay_in_minutes = 0 + include_mode = "INCLUDE_ALL" + severity_level = "AVAILABILITY" + tags = [ "Component:XCC", "Environment:INT" ] + } + rule { + delay_in_minutes = 10 + include_mode = "INCLUDE_ALL" + severity_level = "CUSTOM_ALERT" + tags = [ "Component:XCC", "Environment:INT" ] + } + rule { + delay_in_minutes = 10 + include_mode = "INCLUDE_ALL" + severity_level = "ERRORS" + tags = [ "Component:XCC", "Environment:INT" ] + } + rule { + delay_in_minutes = 30 + include_mode = "INCLUDE_ALL" + severity_level = "PERFORMANCE" + tags = [ "Component:XCC", "Environment:INT" ] + } + rule { + delay_in_minutes = 30 + include_mode = "INCLUDE_ALL" + severity_level = "RESOURCE_CONTENTION" + tags = [ "Component:XCC", "Environment:INT" ] + } + } +} \ No newline at end of file diff --git a/CN_PREPROD/dashboard/cd_xcc_int.tf b/CN_PREPROD/dashboard/cd_xcc_int.tf new file mode 100644 index 00000000..57554b5a --- /dev/null +++ b/CN_PREPROD/dashboard/cd_xcc_int.tf @@ -0,0 +1,294 @@ +# DEFINE dynatrace_dashboard.CD_XCC_INT.id = d226e2ef-2adb-4275-af3d-009ab2ac25e3 +data "dynatrace_management_zone" "CD_XCC_INT"{ name="CD_XCC" } +resource "dynatrace_dashboard" "CD_XCC_INT" { + dashboard_metadata { + name = "CD_XCC INT" + owner = "Ignacio.Goldman@partner.bmwgroup.com" + preset = true + shared = true + tags = [ "XCC" ] + filter { + timeframe = "-24h to now" + } + } + tile { + name = "Custom chart" + configured = true + tile_type = "CUSTOM_CHARTING" + bounds { + height = 304 + left = 38 + top = 228 + width = 1064 + } + filter_config { + type = "MIXED" + custom_name = "Failure rate (HTTP 4xx/5xx errors)" + default_name = "Custom chart" + chart_config { + type = "TIMESERIES" + legend = true + result_metadata { + config { + custom_color = "#ff0000" + key = "nullbuiltin:service.errors.fivexx.rate|AVG|TOTAL|BAR|SERVICE" + last_modified = 1617956393463 + } + config { + custom_color = "#fff29a" + key = "nullbuiltin:service.errors.fourxx.rate|AVG|TOTAL|BAR|SERVICE" + last_modified = 1617956441725 + } + } + series { + type = "BAR" + aggregation = "AVG" + aggregation_rate = "TOTAL" + entity_type = "SERVICE" + metric = "builtin:service.errors.fourxx.rate" + # sort_ascending = false + # sort_column = false + } + series { + type = "BAR" + aggregation = "AVG" + aggregation_rate = "TOTAL" + entity_type = "SERVICE" + metric = "builtin:service.errors.fivexx.rate" + # sort_ascending = false + sort_column = true + } + } + filters { + filter { + entity_type = "SERVICE" + match { + key = "AUTO_TAGS" + values = [ "Component:XCC", "Environment:INT" ] + } + } + } + } + } + tile { + name = "Problems" + configured = true + tile_type = "OPEN_PROBLEMS" + bounds { + height = 152 + left = 950 + top = 38 + width = 152 + } + filter { + management_zone { + name = "CD_XCC" + id = data.dynatrace_management_zone.CD_XCC_INT.id + } + } + } + tile { + name = "Overall Health" + configured = true + tile_type = "HEADER" + bounds { + height = 38 + left = 38 + top = 0 + width = 1064 + } + } + tile { + name = "Markdown" + configured = true + markdown =<<-EOT + --- + + EOT + tile_type = "MARKDOWN" + bounds { + height = 38 + left = 38 + top = 532 + width = 1064 + } + } + tile { + name = "Custom chart" + configured = true + tile_type = "CUSTOM_CHARTING" + bounds { + height = 304 + left = 38 + top = 570 + width = 1064 + } + filter_config { + type = "MIXED" + custom_name = "Response time, Request Count and Number of Errors" + default_name = "Custom chart" + chart_config { + type = "TIMESERIES" + legend = true + result_metadata { + config { + custom_color = "#008cdb" + key = "nullbuiltin:service.requestCount.total|NONE|TOTAL|BAR|SERVICE" + last_modified = 1595275720776 + } + config { + custom_color = "#b4e5f9" + key = "nullbuiltin:service.response.time|AVG|TOTAL|LINE|SERVICE" + last_modified = 1595275686773 + } + config { + custom_color = "#ef651f" + key = "nullbuiltin:service.errors.total.count|NONE|TOTAL|BAR|SERVICE" + last_modified = 1595275955999 + } + } + series { + type = "LINE" + aggregation = "AVG" + aggregation_rate = "TOTAL" + entity_type = "SERVICE" + metric = "builtin:service.response.time" + # sort_ascending = false + # sort_column = false + } + series { + type = "BAR" + aggregation = "NONE" + aggregation_rate = "TOTAL" + entity_type = "SERVICE" + metric = "builtin:service.requestCount.total" + # sort_ascending = false + # sort_column = false + } + series { + type = "BAR" + aggregation = "NONE" + aggregation_rate = "TOTAL" + entity_type = "SERVICE" + metric = "builtin:service.errors.total.count" + # sort_ascending = false + sort_column = true + } + } + filters { + filter { + entity_type = "SERVICE" + match { + key = "AUTO_TAGS" + values = [ "Component:XCC", "Environment:INT" ] + } + } + } + } + } + tile { + name = "Markdown" + configured = true + markdown =<<-EOT + --- + + EOT + tile_type = "MARKDOWN" + bounds { + height = 38 + left = 38 + top = 190 + width = 1064 + } + } + tile { + name = "" + chart_visible = true + configured = true + tile_type = "DATABASES_OVERVIEW" + bounds { + height = 152 + left = 646 + top = 38 + width = 190 + } + filter_config { + type = "DATABASE" + custom_name = "Databases" + default_name = "Databases" + chart_config { + type = "TIMESERIES" + legend = true + } + filters { + filter { + entity_type = "DATABASE" + match { + key = "AUTO_TAGS" + values = [ "Component:XCC", "Environment:INT" ] + } + } + } + } + } + tile { + name = "" + chart_visible = true + configured = true + tile_type = "SERVICES" + bounds { + height = 152 + left = 342 + top = 38 + width = 190 + } + filter_config { + type = "SERVICE" + custom_name = "Services" + default_name = "Services" + chart_config { + type = "TIMESERIES" + legend = true + } + filters { + filter { + entity_type = "SERVICE" + match { + key = "AUTO_TAGS" + values = [ "Component:XCC", "Environment:INT" ] + } + } + } + } + } + tile { + name = "" + chart_visible = true + configured = true + tile_type = "HOSTS" + bounds { + height = 152 + left = 38 + top = 38 + width = 190 + } + filter_config { + type = "HOST" + custom_name = "Hosts" + default_name = "Hosts" + chart_config { + type = "TIMESERIES" + legend = true + } + filters { + filter { + entity_type = "HOST" + match { + key = "AUTO_TAGS" + values = [ "Component:XCC", "Environment:INT" ] + } + } + } + } + } +} \ No newline at end of file diff --git a/CN_PREPROD/dashboard/cd_xcc_test.tf b/CN_PREPROD/dashboard/cd_xcc_test.tf new file mode 100644 index 00000000..25c3bf1a --- /dev/null +++ b/CN_PREPROD/dashboard/cd_xcc_test.tf @@ -0,0 +1,294 @@ +# DEFINE dynatrace_dashboard.CD_XCC_TEST.id = 893cec45-7b5a-462a-bcc9-1e507b0b1832 +data "dynatrace_management_zone" "CD_XCC_TEST"{ name="CD_XCC" } +resource "dynatrace_dashboard" "CD_XCC_TEST" { + dashboard_metadata { + name = "CD_XCC TEST" + owner = "Ignacio.Goldman@partner.bmwgroup.com" + preset = true + shared = true + tags = [ "XCC" ] + filter { + timeframe = "-24h to now" + } + } + tile { + name = "Custom chart" + configured = true + tile_type = "CUSTOM_CHARTING" + bounds { + height = 304 + left = 38 + top = 228 + width = 1064 + } + filter_config { + type = "MIXED" + custom_name = "Failure rate (HTTP 4xx/5xx errors)" + default_name = "Custom chart" + chart_config { + type = "TIMESERIES" + legend = true + result_metadata { + config { + custom_color = "#ff0000" + key = "nullbuiltin:service.errors.fivexx.rate|AVG|TOTAL|BAR|SERVICE" + last_modified = 1617956393463 + } + config { + custom_color = "#fff29a" + key = "nullbuiltin:service.errors.fourxx.rate|AVG|TOTAL|BAR|SERVICE" + last_modified = 1617956441725 + } + } + series { + type = "BAR" + aggregation = "AVG" + aggregation_rate = "TOTAL" + entity_type = "SERVICE" + metric = "builtin:service.errors.fourxx.rate" + # sort_ascending = false + # sort_column = false + } + series { + type = "BAR" + aggregation = "AVG" + aggregation_rate = "TOTAL" + entity_type = "SERVICE" + metric = "builtin:service.errors.fivexx.rate" + # sort_ascending = false + sort_column = true + } + } + filters { + filter { + entity_type = "SERVICE" + match { + key = "AUTO_TAGS" + values = [ "Component:XCC", "Environment:TEST" ] + } + } + } + } + } + tile { + name = "Problems" + configured = true + tile_type = "OPEN_PROBLEMS" + bounds { + height = 152 + left = 950 + top = 38 + width = 152 + } + filter { + management_zone { + name = "CD_XCC" + id = data.dynatrace_management_zone.CD_XCC_TEST.id + } + } + } + tile { + name = "Overall Health" + configured = true + tile_type = "HEADER" + bounds { + height = 38 + left = 38 + top = 0 + width = 1064 + } + } + tile { + name = "Markdown" + configured = true + markdown =<<-EOT + --- + + EOT + tile_type = "MARKDOWN" + bounds { + height = 38 + left = 38 + top = 532 + width = 1064 + } + } + tile { + name = "Custom chart" + configured = true + tile_type = "CUSTOM_CHARTING" + bounds { + height = 304 + left = 38 + top = 570 + width = 1064 + } + filter_config { + type = "MIXED" + custom_name = "Response time, Request Count and Number of Errors" + default_name = "Custom chart" + chart_config { + type = "TIMESERIES" + legend = true + result_metadata { + config { + custom_color = "#008cdb" + key = "nullbuiltin:service.requestCount.total|NONE|TOTAL|BAR|SERVICE" + last_modified = 1595275720776 + } + config { + custom_color = "#b4e5f9" + key = "nullbuiltin:service.response.time|AVG|TOTAL|LINE|SERVICE" + last_modified = 1595275686773 + } + config { + custom_color = "#ef651f" + key = "nullbuiltin:service.errors.total.count|NONE|TOTAL|BAR|SERVICE" + last_modified = 1595275955999 + } + } + series { + type = "LINE" + aggregation = "AVG" + aggregation_rate = "TOTAL" + entity_type = "SERVICE" + metric = "builtin:service.response.time" + # sort_ascending = false + # sort_column = false + } + series { + type = "BAR" + aggregation = "NONE" + aggregation_rate = "TOTAL" + entity_type = "SERVICE" + metric = "builtin:service.requestCount.total" + # sort_ascending = false + # sort_column = false + } + series { + type = "BAR" + aggregation = "NONE" + aggregation_rate = "TOTAL" + entity_type = "SERVICE" + metric = "builtin:service.errors.total.count" + # sort_ascending = false + sort_column = true + } + } + filters { + filter { + entity_type = "SERVICE" + match { + key = "AUTO_TAGS" + values = [ "Component:XCC", "Environment:TEST" ] + } + } + } + } + } + tile { + name = "Markdown" + configured = true + markdown =<<-EOT + --- + + EOT + tile_type = "MARKDOWN" + bounds { + height = 38 + left = 38 + top = 190 + width = 1064 + } + } + tile { + name = "" + chart_visible = true + configured = true + tile_type = "DATABASES_OVERVIEW" + bounds { + height = 152 + left = 646 + top = 38 + width = 190 + } + filter_config { + type = "DATABASE" + custom_name = "Databases" + default_name = "Databases" + chart_config { + type = "TIMESERIES" + legend = true + } + filters { + filter { + entity_type = "DATABASE" + match { + key = "AUTO_TAGS" + values = [ "Component:XCC", "Environment:TEST" ] + } + } + } + } + } + tile { + name = "" + chart_visible = true + configured = true + tile_type = "SERVICES" + bounds { + height = 152 + left = 342 + top = 38 + width = 190 + } + filter_config { + type = "SERVICE" + custom_name = "Services" + default_name = "Services" + chart_config { + type = "TIMESERIES" + legend = true + } + filters { + filter { + entity_type = "SERVICE" + match { + key = "AUTO_TAGS" + values = [ "Component:XCC", "Environment:TEST" ] + } + } + } + } + } + tile { + name = "" + chart_visible = true + configured = true + tile_type = "HOSTS" + bounds { + height = 152 + left = 38 + top = 38 + width = 190 + } + filter_config { + type = "HOST" + custom_name = "Hosts" + default_name = "Hosts" + chart_config { + type = "TIMESERIES" + legend = true + } + filters { + filter { + entity_type = "HOST" + match { + key = "AUTO_TAGS" + values = [ "Component:XCC", "Environment:TEST" ] + } + } + } + } + } +} \ No newline at end of file diff --git a/CN_PREPROD/management_zone/cd_xcc.tf b/CN_PREPROD/management_zone/cd_xcc.tf new file mode 100644 index 00000000..e7077dad --- /dev/null +++ b/CN_PREPROD/management_zone/cd_xcc.tf @@ -0,0 +1,52 @@ +# DEFINE dynatrace_management_zone.CD_XCC.id = -269616454953989352 +resource "dynatrace_management_zone" "CD_XCC" { + name = "CD_XCC" + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(Service),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(SERVICE),databaseName.exists(),toRelationship.calls(type(SERVICE),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade")) + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(PROCESS_GROUP_INSTANCE),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(HOST),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(Service),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(SERVICE),databaseName.exists(),toRelationship.calls(type(SERVICE),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886")) + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(PROCESS_GROUP_INSTANCE),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(HOST),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } +} From 7fbb69661dfcf2e35576b115fdf6e7c67f9ad8ab Mon Sep 17 00:00:00 2001 From: Patryk Gudalewicz Date: Wed, 1 Mar 2023 18:54:02 +0100 Subject: [PATCH 2/6] "Migrating from Monaco to Terraform for management zone: CD_XCC" --- CN_PROD/management_zone/cd_xcc.tf | 52 +++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 CN_PROD/management_zone/cd_xcc.tf diff --git a/CN_PROD/management_zone/cd_xcc.tf b/CN_PROD/management_zone/cd_xcc.tf new file mode 100644 index 00000000..6cd2e534 --- /dev/null +++ b/CN_PROD/management_zone/cd_xcc.tf @@ -0,0 +1,52 @@ +# DEFINE dynatrace_management_zone.CD_XCC.id = 1418341813031385258 +resource "dynatrace_management_zone" "CD_XCC" { + name = "CD_XCC" + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(Service),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(SERVICE),databaseName.exists(),toRelationship.calls(type(SERVICE),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade")) + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(PROCESS_GROUP_INSTANCE),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(HOST),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(Service),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(SERVICE),databaseName.exists(),toRelationship.calls(type(SERVICE),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886")) + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(PROCESS_GROUP_INSTANCE),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(HOST),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } +} From 60beecbe5efe89069c327666f58bbb072ea75e2d Mon Sep 17 00:00:00 2001 From: Patryk Gudalewicz Date: Wed, 1 Mar 2023 18:58:35 +0100 Subject: [PATCH 3/6] "Migrating from Monaco to Terraform for management zone: CD_XCC" --- EMEA_PREPROD/management_zone/cd_xcc.tf | 84 ++++++++++++++++++++++++++ 1 file changed, 84 insertions(+) create mode 100644 EMEA_PREPROD/management_zone/cd_xcc.tf diff --git a/EMEA_PREPROD/management_zone/cd_xcc.tf b/EMEA_PREPROD/management_zone/cd_xcc.tf new file mode 100644 index 00000000..714adb44 --- /dev/null +++ b/EMEA_PREPROD/management_zone/cd_xcc.tf @@ -0,0 +1,84 @@ +# DEFINE dynatrace_management_zone.CD_XCC.id = -8695410134780987301 +resource "dynatrace_management_zone" "CD_XCC" { + name = "CD_XCC" + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(Service),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(SERVICE),databaseName.exists(),toRelationship.calls(type(SERVICE),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade")) + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(PROCESS_GROUP_INSTANCE),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(HOST),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(Service),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(SERVICE),databaseName.exists(),toRelationship.calls(type(SERVICE),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886")) + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(PROCESS_GROUP_INSTANCE),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(HOST),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + rules { + type = "AWS_RELATIONAL_DATABASE_SERVICE" + # enabled = false + conditions { + key { + type = "STATIC" + attribute = "AWS_RELATIONAL_DATABASE_SERVICE_DB_NAME" + } + string { + case_sensitive = true + # negate = false + operator = "BEGINS_WITH" + value = "xcc_next" + } + } + } + rules { + type = "AWS_ACCOUNT" + # enabled = false + conditions { + key { + type = "STATIC" + attribute = "AWS_ACCOUNT_ID" + } + string { + case_sensitive = true + # negate = false + operator = "EQUALS" + value = "486530126820" + } + } + } +} From 7ba5257233fb02439bfde96dd88985091c0a403f Mon Sep 17 00:00:00 2001 From: Patryk Gudalewicz Date: Wed, 1 Mar 2023 19:07:35 +0100 Subject: [PATCH 4/6] "Migrating from Monaco to Terraform for management zone: CD_XCC" --- EMEA_PROD/alerting/cd_xcc_prod.tf | 38 +++++++++++++++++++++ EMEA_PROD/management_zone/cd_xcc.tf | 52 +++++++++++++++++++++++++++++ 2 files changed, 90 insertions(+) create mode 100644 EMEA_PROD/alerting/cd_xcc_prod.tf create mode 100644 EMEA_PROD/management_zone/cd_xcc.tf diff --git a/EMEA_PROD/alerting/cd_xcc_prod.tf b/EMEA_PROD/alerting/cd_xcc_prod.tf new file mode 100644 index 00000000..5413927c --- /dev/null +++ b/EMEA_PROD/alerting/cd_xcc_prod.tf @@ -0,0 +1,38 @@ +# DEFINE dynatrace_alerting.CD_XCC_PROD.id = vu9U3hXa3q0AAAABABhidWlsdGluOmFsZXJ0aW5nLnByb2ZpbGUABnRlbmFudAAGdGVuYW50ACQxMTM2Y2MxOS03YTEzLTMyMTQtODViOS01N2JmNWE0ZGI1Njm-71TeFdrerQ +data "dynatrace_management_zone" "CD_XCC_PROD"{ name="CD_XCC" } +resource "dynatrace_alerting" "CD_XCC_PROD" { + name = "CD_XCC PROD" + management_zone = data.dynatrace_management_zone.CD_XCC_PROD.id + rules { + rule { + delay_in_minutes = 0 + include_mode = "INCLUDE_ALL" + severity_level = "AVAILABILITY" + tags = [ "Component:XCC", "Environment:PROD" ] + } + rule { + delay_in_minutes = 10 + include_mode = "INCLUDE_ALL" + severity_level = "CUSTOM_ALERT" + tags = [ "Component:XCC", "Environment:PROD" ] + } + rule { + delay_in_minutes = 10 + include_mode = "INCLUDE_ALL" + severity_level = "ERRORS" + tags = [ "Component:XCC", "Environment:PROD" ] + } + rule { + delay_in_minutes = 30 + include_mode = "INCLUDE_ALL" + severity_level = "PERFORMANCE" + tags = [ "Component:XCC", "Environment:PROD" ] + } + rule { + delay_in_minutes = 30 + include_mode = "INCLUDE_ALL" + severity_level = "RESOURCE_CONTENTION" + tags = [ "Component:XCC", "Environment:PROD" ] + } + } +} \ No newline at end of file diff --git a/EMEA_PROD/management_zone/cd_xcc.tf b/EMEA_PROD/management_zone/cd_xcc.tf new file mode 100644 index 00000000..f265bb80 --- /dev/null +++ b/EMEA_PROD/management_zone/cd_xcc.tf @@ -0,0 +1,52 @@ +# DEFINE dynatrace_management_zone.CD_XCC.id = 726963056829115815 +resource "dynatrace_management_zone" "CD_XCC" { + name = "CD_XCC" + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(Service),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(SERVICE),databaseName.exists(),toRelationship.calls(type(SERVICE),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade")) + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(PROCESS_GROUP_INSTANCE),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(HOST),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(Service),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(SERVICE),databaseName.exists(),toRelationship.calls(type(SERVICE),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886")) + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(PROCESS_GROUP_INSTANCE),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(HOST),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } +} From 1c473837718cbbd9b6fcd96341a3e1cb9bbfdd7c Mon Sep 17 00:00:00 2001 From: Patryk Gudalewicz Date: Wed, 1 Mar 2023 19:10:51 +0100 Subject: [PATCH 5/6] "Migrating from Monaco to Terraform for management zone: CD_XCC" --- NA_PREPROD/alerting/cd_xcc_int.tf | 38 ++++++++++++++++++++ NA_PREPROD/management_zone/cd_xcc.tf | 52 ++++++++++++++++++++++++++++ 2 files changed, 90 insertions(+) create mode 100644 NA_PREPROD/alerting/cd_xcc_int.tf create mode 100644 NA_PREPROD/management_zone/cd_xcc.tf diff --git a/NA_PREPROD/alerting/cd_xcc_int.tf b/NA_PREPROD/alerting/cd_xcc_int.tf new file mode 100644 index 00000000..f821f8e0 --- /dev/null +++ b/NA_PREPROD/alerting/cd_xcc_int.tf @@ -0,0 +1,38 @@ +# DEFINE dynatrace_alerting.CD_XCC_INT.id = vu9U3hXa3q0AAAABABhidWlsdGluOmFsZXJ0aW5nLnByb2ZpbGUABnRlbmFudAAGdGVuYW50ACQ4YTg2NWU5ZS0yMzJmLTM4NDktYTAyYi04Y2Q2ZTMyMDg5NmG-71TeFdrerQ +data "dynatrace_management_zone" "CD_XCC_INT"{ name="CD_XCC" } +resource "dynatrace_alerting" "CD_XCC_INT" { + name = "CD_XCC INT" + management_zone = data.dynatrace_management_zone.CD_XCC_INT.id + rules { + rule { + delay_in_minutes = 0 + include_mode = "INCLUDE_ALL" + severity_level = "AVAILABILITY" + tags = [ "Component:XCC", "Environment:INT" ] + } + rule { + delay_in_minutes = 10 + include_mode = "INCLUDE_ALL" + severity_level = "CUSTOM_ALERT" + tags = [ "Component:XCC", "Environment:INT" ] + } + rule { + delay_in_minutes = 10 + include_mode = "INCLUDE_ALL" + severity_level = "ERRORS" + tags = [ "Component:XCC", "Environment:INT" ] + } + rule { + delay_in_minutes = 30 + include_mode = "INCLUDE_ALL" + severity_level = "PERFORMANCE" + tags = [ "Component:XCC", "Environment:INT" ] + } + rule { + delay_in_minutes = 30 + include_mode = "INCLUDE_ALL" + severity_level = "RESOURCE_CONTENTION" + tags = [ "Component:XCC", "Environment:INT" ] + } + } +} \ No newline at end of file diff --git a/NA_PREPROD/management_zone/cd_xcc.tf b/NA_PREPROD/management_zone/cd_xcc.tf new file mode 100644 index 00000000..39b446af --- /dev/null +++ b/NA_PREPROD/management_zone/cd_xcc.tf @@ -0,0 +1,52 @@ +# DEFINE dynatrace_management_zone.CD_XCC.id = -4875302022475074252 +resource "dynatrace_management_zone" "CD_XCC" { + name = "CD_XCC" + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(Service),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(SERVICE),databaseName.exists(),toRelationship.calls(type(SERVICE),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade")) + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(PROCESS_GROUP_INSTANCE),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(HOST),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(Service),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(SERVICE),databaseName.exists(),toRelationship.calls(type(SERVICE),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886")) + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(PROCESS_GROUP_INSTANCE),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(HOST),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } +} From 09c14f5055754ec0d87f1634271be1c955f87b6c Mon Sep 17 00:00:00 2001 From: Patryk Gudalewicz Date: Wed, 1 Mar 2023 19:13:53 +0100 Subject: [PATCH 6/6] "Migrating from Monaco to Terraform for management zone: CD_XCC" --- NA_PROD/alerting/cd_xcc_prod.tf | 38 ++++++++++++++++++++++ NA_PROD/management_zone/cd_xcc.tf | 52 +++++++++++++++++++++++++++++++ 2 files changed, 90 insertions(+) create mode 100644 NA_PROD/alerting/cd_xcc_prod.tf create mode 100644 NA_PROD/management_zone/cd_xcc.tf diff --git a/NA_PROD/alerting/cd_xcc_prod.tf b/NA_PROD/alerting/cd_xcc_prod.tf new file mode 100644 index 00000000..5f6b36f4 --- /dev/null +++ b/NA_PROD/alerting/cd_xcc_prod.tf @@ -0,0 +1,38 @@ +# DEFINE dynatrace_alerting.CD_XCC_PROD.id = vu9U3hXa3q0AAAABABhidWlsdGluOmFsZXJ0aW5nLnByb2ZpbGUABnRlbmFudAAGdGVuYW50ACRiMGI3ODQyNy01ZTFmLTNhNDUtYWY1OC1jZDA4MjlmZGJhYzS-71TeFdrerQ +data "dynatrace_management_zone" "CD_XCC_PROD"{ name="CD_XCC" } +resource "dynatrace_alerting" "CD_XCC_PROD" { + name = "CD_XCC PROD" + management_zone = data.dynatrace_management_zone.CD_XCC_PROD.id + rules { + rule { + delay_in_minutes = 0 + include_mode = "INCLUDE_ALL" + severity_level = "AVAILABILITY" + tags = [ "Component:XCC", "Environment:PROD" ] + } + rule { + delay_in_minutes = 10 + include_mode = "INCLUDE_ALL" + severity_level = "CUSTOM_ALERT" + tags = [ "Component:XCC", "Environment:PROD" ] + } + rule { + delay_in_minutes = 10 + include_mode = "INCLUDE_ALL" + severity_level = "ERRORS" + tags = [ "Component:XCC", "Environment:PROD" ] + } + rule { + delay_in_minutes = 30 + include_mode = "INCLUDE_ALL" + severity_level = "PERFORMANCE" + tags = [ "Component:XCC", "Environment:PROD" ] + } + rule { + delay_in_minutes = 30 + include_mode = "INCLUDE_ALL" + severity_level = "RESOURCE_CONTENTION" + tags = [ "Component:XCC", "Environment:PROD" ] + } + } +} \ No newline at end of file diff --git a/NA_PROD/management_zone/cd_xcc.tf b/NA_PROD/management_zone/cd_xcc.tf new file mode 100644 index 00000000..553bf39e --- /dev/null +++ b/NA_PROD/management_zone/cd_xcc.tf @@ -0,0 +1,52 @@ +# DEFINE dynatrace_management_zone.CD_XCC.id = 2333555447941977219 +resource "dynatrace_management_zone" "CD_XCC" { + name = "CD_XCC" + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(Service),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(SERVICE),databaseName.exists(),toRelationship.calls(type(SERVICE),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade")) + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(PROCESS_GROUP_INSTANCE),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(HOST),tag("compass-id:xcc-campaigns","compass-id:xcc-settings","compass-id:xcc-statistics","compass-id:xcc-cmgr","compass-id:xcc-users","compass-id:xcc-next-campaigns","compass-id:xcc-next-legacy-facade") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(Service),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(SERVICE),databaseName.exists(),toRelationship.calls(type(SERVICE),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886")) + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(PROCESS_GROUP_INSTANCE),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } + entity_selector_based_rule { + enabled = true + selector =<<-EOT + type(HOST),tag("app-id:APP-18886","[AWS]APP-ID:APP-18886") + EOT + } +}