"Migrating from Monaco to Terraform for management zone: CD_Billing_Buffet"

CD_Billing_Buffet
Patryk Gudalewicz 2023-03-01 18:59:11 +01:00
parent 2d57705b6e
commit ec8fc3e167
4 changed files with 909 additions and 0 deletions

View File

@ -0,0 +1,23 @@
# DEFINE dynatrace_alerting.CD_Billing_Buffet_PROD.id = vu9U3hXa3q0AAAABABhidWlsdGluOmFsZXJ0aW5nLnByb2ZpbGUABnRlbmFudAAGdGVuYW50ACQ5ZDcyMjYxZS0wYjhmLTMyMWUtODk4Mi0xYTQyOTQxYjZjZDW-71TeFdrerQ
data "dynatrace_management_zone" "CD_Billing_Buffet_PROD"{ name="CD_Billing_Buffet" }
resource "dynatrace_alerting" "CD_Billing_Buffet_PROD" {
name = "CD_Billing_Buffet PROD"
management_zone = data.dynatrace_management_zone.CD_Billing_Buffet_PROD.id
rules {
rule {
delay_in_minutes = 5
include_mode = "NONE"
severity_level = "AVAILABILITY"
}
rule {
delay_in_minutes = 0
include_mode = "NONE"
severity_level = "CUSTOM_ALERT"
}
rule {
delay_in_minutes = 10
include_mode = "NONE"
severity_level = "ERRORS"
}
}
}

View File

@ -0,0 +1,321 @@
# DEFINE dynatrace_dashboard.CD_Billing_Buffet_PROD.id = 6c46a079-dd9c-4752-ba19-b411195ca375
data "dynatrace_management_zone" "CD_Billing_Buffet_PROD"{ name="CD_Billing_Buffet" }
resource "dynatrace_dashboard" "CD_Billing_Buffet_PROD" {
dashboard_metadata {
name = "CD_Billing_Buffet PROD"
owner = "Ignacio.Goldman@partner.bmwgroup.com"
preset = true
shared = true
tags = [ "Billing_Buffet" ]
filter {
timeframe = "-24h to now"
}
}
tile {
name = "Custom chart"
configured = true
tile_type = "CUSTOM_CHARTING"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
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:Billing_Buffet", "Environment:PROD" ]
}
}
}
}
}
tile {
name = "Problems"
configured = true
tile_type = "OPEN_PROBLEMS"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 152
left = 950
top = 38
width = 152
}
filter {
management_zone {
name = "CD_Billing_Buffet"
id = data.dynatrace_management_zone.CD_Billing_Buffet_PROD.id
}
}
}
tile {
name = "Overall Health"
configured = true
tile_type = "HEADER"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 38
left = 38
top = 0
width = 1064
}
}
tile {
name = "Markdown"
configured = true
markdown =<<-EOT
---
EOT
tile_type = "MARKDOWN"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 38
left = 38
top = 532
width = 1064
}
}
tile {
name = "Custom chart"
configured = true
tile_type = "CUSTOM_CHARTING"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
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:Billing_Buffet", "Environment:PROD" ]
}
}
}
}
}
tile {
name = "Markdown"
configured = true
markdown =<<-EOT
---
EOT
tile_type = "MARKDOWN"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 38
left = 38
top = 190
width = 1064
}
}
tile {
name = ""
chart_visible = true
configured = true
tile_type = "DATABASES_OVERVIEW"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
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:Billing_Buffet", "Environment:PROD" ]
}
}
}
}
}
tile {
name = ""
chart_visible = true
configured = true
tile_type = "SERVICES"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
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:Billing_Buffet", "Environment:PROD" ]
}
}
}
}
}
tile {
name = ""
chart_visible = true
configured = true
tile_type = "HOSTS"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
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:Billing_Buffet", "Environment:PROD" ]
}
}
}
}
}
}

View File

@ -0,0 +1,470 @@
# DEFINE dynatrace_dashboard.CD_Billing_Buffet_REST_Interface.id = 94dbbfcf-e129-401e-ad1b-f3140881bbc7
data "dynatrace_management_zone" "CD_Billing_Buffet_REST_Interface"{ name="CD_Billing_Buffet" }
resource "dynatrace_dashboard" "CD_Billing_Buffet_REST_Interface" {
dashboard_metadata {
name = "CD_Billing_Buffet REST Interface"
owner = "Ignacio.Goldman@partner.bmwgroup.com"
preset = true
shared = true
unknowns = jsonencode({
"popularity": 1
})
filter {
management_zone {
name = "CD_Billing_Buffet"
id = data.dynatrace_management_zone.CD_Billing_Buffet_REST_Interface.id
}
}
}
tile {
name = "Custom chart"
configured = true
tile_type = "CUSTOM_CHARTING"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 380
left = 0
top = 0
width = 1216
}
filter_config {
type = "MIXED"
custom_name = "Billing Provider service"
default_name = "Custom chart"
chart_config {
type = "TIMESERIES"
legend = true
result_metadata {
config {
custom_color = "#7c38a1"
key = "SERVICE-B1B3BA0380BC2513¦SERVICE»SERVICE-B1B3BA0380BC2513»truebuiltin:service.requestCount.total|NONE|TOTAL|BAR|SERVICE"
last_modified = 1613039920644
}
config {
custom_color = "#b4e5f9"
key = "SERVICE-0B909ADC644DC666¦SERVICE»SERVICE-0B909ADC644DC666»truebuiltin:service.requestCount.total|NONE|TOTAL|BAR|SERVICE"
last_modified = 1613723321241
}
config {
custom_color = "#ef651f"
key = "SERVICE-0B909ADC644DC666¦SERVICE»SERVICE-0B909ADC644DC666»truebuiltin:service.response.time|MAX|TOTAL|LINE|SERVICE"
last_modified = 1613723296508
}
config {
custom_color = "#ff0000"
key = "SERVICE-B1B3BA0380BC2513¦SERVICE»SERVICE-B1B3BA0380BC2513»truebuiltin:service.response.time|MAX|TOTAL|LINE|SERVICE"
last_modified = 1613039931576
}
config {
custom_color = "#fff29a"
key = "SERVICE-B1B3BA0380BC2513¦SERVICE»SERVICE-B1B3BA0380BC2513»truebuiltin:service.response.time|AVG|TOTAL|LINE|SERVICE"
last_modified = 1613039925298
}
}
series {
type = "LINE"
aggregation = "AVG"
aggregation_rate = "TOTAL"
entity_type = "SERVICE"
metric = "builtin:service.response.time"
# sort_ascending = false
# sort_column = false
dimension {
name = "dt.entity.service"
entity_dimension = true
id = "0"
}
}
series {
type = "BAR"
aggregation = "NONE"
aggregation_rate = "TOTAL"
entity_type = "SERVICE"
metric = "builtin:service.requestCount.total"
# sort_ascending = false
# sort_column = false
dimension {
name = "dt.entity.service"
entity_dimension = true
id = "0"
}
}
series {
type = "LINE"
aggregation = "MAX"
aggregation_rate = "TOTAL"
entity_type = "SERVICE"
metric = "builtin:service.response.time"
# sort_ascending = false
sort_column = true
dimension {
name = "dt.entity.service"
entity_dimension = true
id = "0"
}
}
}
filters {
filter {
entity_type = "SERVICE"
match {
key = "SPECIFIC_ENTITIES"
values = [ "SERVICE-0B909ADC644DC666" ]
}
}
}
}
}
tile {
name = "Custom chart"
configured = true
tile_type = "CUSTOM_CHARTING"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 380
left = 0
top = 380
width = 1216
}
filter_config {
type = "MIXED"
custom_name = "All Buffet Services"
default_name = "Custom chart"
chart_config {
type = "TIMESERIES"
legend = true
result_metadata {
config {
custom_color = "#7c38a1"
key = "SERVICE-B1B3BA0380BC2513¦SERVICE»SERVICE-B1B3BA0380BC2513»truebuiltin:service.requestCount.total|NONE|TOTAL|BAR|SERVICE"
last_modified = 1613039920644
}
config {
custom_color = "#ff0000"
key = "SERVICE-B1B3BA0380BC2513¦SERVICE»SERVICE-B1B3BA0380BC2513»truebuiltin:service.response.time|MAX|TOTAL|LINE|SERVICE"
last_modified = 1613039931576
}
config {
custom_color = "#fff29a"
key = "SERVICE-B1B3BA0380BC2513¦SERVICE»SERVICE-B1B3BA0380BC2513»truebuiltin:service.response.time|AVG|TOTAL|LINE|SERVICE"
last_modified = 1613039925298
}
}
series {
type = "LINE"
aggregation = "AVG"
aggregation_rate = "TOTAL"
entity_type = "SERVICE"
metric = "builtin:service.response.time"
# sort_ascending = false
# sort_column = false
dimension {
name = "dt.entity.service"
entity_dimension = true
id = "0"
}
}
series {
type = "BAR"
aggregation = "NONE"
aggregation_rate = "TOTAL"
entity_type = "SERVICE"
metric = "builtin:service.requestCount.total"
# sort_ascending = false
# sort_column = false
dimension {
name = "dt.entity.service"
entity_dimension = true
id = "0"
}
}
series {
type = "LINE"
aggregation = "MAX"
aggregation_rate = "TOTAL"
entity_type = "SERVICE"
metric = "builtin:service.response.time"
# sort_ascending = false
sort_column = true
dimension {
name = "dt.entity.service"
entity_dimension = true
id = "0"
}
}
}
}
}
tile {
name = "Host health"
chart_visible = true
configured = true
tile_type = "HOSTS"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 228
left = 1216
top = 0
width = 228
}
}
tile {
name = "Database performance"
assigned_entities = [ "SERVICE-9B9E46BE5685FF0B" ]
configured = true
tile_type = "DATABASE"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 152
left = 1216
top = 228
width = 304
}
}
tile {
name = "Service or request"
assigned_entities = [ "SERVICE-899B9AF0DBE6B752" ]
configured = true
tile_type = "SERVICE_VERSATILE"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 380
left = 1216
top = 380
width = 418
}
}
tile {
name = "Database health"
chart_visible = true
configured = true
tile_type = "DATABASES_OVERVIEW"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 228
left = 1444
top = 0
width = 190
}
}
tile {
name = "Problems"
configured = true
tile_type = "OPEN_PROBLEMS"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 152
left = 1482
top = 760
width = 152
}
filter {
management_zone {
name = "CD_Billing_Buffet"
id = data.dynatrace_management_zone.CD_Billing_Buffet_REST_Interface.id
}
}
}
tile {
name = "Custom chart"
configured = true
tile_type = "CUSTOM_CHARTING"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 532
left = 0
top = 760
width = 1482
}
filter {
management_zone {
name = "CD_Billing_Buffet"
id = data.dynatrace_management_zone.CD_Billing_Buffet_REST_Interface.id
}
}
filter_config {
type = "MIXED"
custom_name = "CPU time of services"
default_name = "Custom chart"
chart_config {
type = "TOP_LIST"
legend = true
series {
type = "LINE"
aggregation = "AVG"
aggregation_rate = "TOTAL"
entity_type = "SERVICE"
metric = "builtin:service.cpu.perRequest"
# sort_ascending = false
sort_column = true
dimension {
name = "dt.entity.service"
entity_dimension = true
id = "0"
}
}
}
}
}
tile {
name = "Custom chart"
configured = true
tile_type = "CUSTOM_CHARTING"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 266
left = 0
top = 1634
width = 1482
}
filter_config {
type = "MIXED"
custom_name = "Garbage collection suspension time (maximum)"
default_name = "Custom chart"
chart_config {
type = "TIMESERIES"
axis_limits = jsonencode({
"LEFT_MAX": 15
})
left_axis_custom_unit = "Percent"
legend = true
series {
type = "LINE"
aggregation = "MAX"
aggregation_rate = "TOTAL"
entity_type = "PROCESS_GROUP_INSTANCE"
metric = "builtin:tech.jvm.memory.gc.suspensionTime"
# sort_ascending = false
sort_column = true
dimension {
name = "dt.entity.process_group_instance"
entity_dimension = true
id = "0"
}
}
}
}
}
tile {
name = "Custom chart"
configured = true
tile_type = "CUSTOM_CHARTING"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 342
left = 0
top = 1292
width = 1482
}
filter {
management_zone {
name = "CD_Billing_Buffet"
id = data.dynatrace_management_zone.CD_Billing_Buffet_REST_Interface.id
}
}
filter_config {
type = "MIXED"
custom_name = "CPU time of services"
default_name = "Custom chart"
chart_config {
type = "TIMESERIES"
axis_limits = jsonencode({
"LEFT_MAX": 6
})
left_axis_custom_unit = "Second"
legend = true
series {
type = "BAR"
aggregation = "AVG"
aggregation_rate = "TOTAL"
entity_type = "SERVICE"
metric = "builtin:service.cpu.perRequest"
# sort_ascending = false
sort_column = true
dimension {
name = "dt.entity.service"
entity_dimension = true
id = "0"
}
}
}
}
}
tile {
name = "Custom chart"
configured = true
tile_type = "CUSTOM_CHARTING"
unknowns = jsonencode({
"isAutoRefreshDisabled": false
})
bounds {
height = 304
left = 0
top = 1900
width = 1482
}
filter_config {
type = "MIXED"
custom_name = "Requests of store (oibilling)"
default_name = "Custom chart"
chart_config {
type = "TIMESERIES"
legend = true
result_metadata {
config {
custom_color = "#ef651f"
key = "nullbuiltin:service.errors.group.total.count|NONE|TOTAL|BAR|MONITORED_ENTITY˟SERVICE_METHOD_GROUP"
last_modified = 1613733289146
}
}
series {
type = "BAR"
aggregation = "NONE"
aggregation_rate = "TOTAL"
entity_type = "MONITORED_ENTITY˟SERVICE_METHOD_GROUP"
metric = "builtin:service.errors.group.total.successCount"
# sort_ascending = false
sort_column = true
}
series {
type = "LINE"
aggregation = "AVG"
aggregation_rate = "TOTAL"
entity_type = "SERVICE"
metric = "builtin:service.response.time"
# sort_ascending = false
sort_column = true
}
}
filters {
filter {
entity_type = "SERVICE"
match {
key = "SPECIFIC_ENTITIES"
values = [ "SERVICE-21BD8D5BF0B56A8A", "SERVICE-4917D526EEA112CC", "SERVICE-3594B360A7CFEE45", "SERVICE-899B9AF0DBE6B752" ]
}
}
}
}
}
}

View File

@ -0,0 +1,95 @@
# DEFINE dynatrace_management_zone.CD_Billing_Buffet.id = 8678780206055840222
resource "dynatrace_management_zone" "CD_Billing_Buffet" {
name = "CD_Billing_Buffet"
rules {
type = "CLOUD_APPLICATION"
enabled = true
conditions {
key {
type = "STATIC"
attribute = "CLOUD_APPLICATION_NAME"
}
string {
case_sensitive = true
# negate = false
operator = "CONTAINS"
value = "Buffet"
}
}
}
rules {
type = "CLOUD_APPLICATION_NAMESPACE"
enabled = true
conditions {
key {
type = "STATIC"
attribute = "CLOUD_APPLICATION_NAMESPACE_NAME"
}
string {
case_sensitive = true
# negate = false
operator = "CONTAINS"
value = "Buffet"
}
}
}
rules {
type = "HOST"
enabled = true
conditions {
key {
type = "STATIC"
attribute = "HOST_TAGS"
}
tag {
# negate = false
operator = "EQUALS"
value {
context = "CONTEXTLESS"
key = "Component"
value = "Buffet"
}
}
}
}
rules {
type = "PROCESS_GROUP"
enabled = true
propagation_types = [ "PROCESS_GROUP_TO_HOST" ]
conditions {
key {
type = "STATIC"
attribute = "PROCESS_GROUP_TAGS"
}
tag {
# negate = false
operator = "EQUALS"
value {
context = "CONTEXTLESS"
key = "Component"
value = "Buffet"
}
}
}
}
rules {
type = "SERVICE"
enabled = true
propagation_types = [ "SERVICE_TO_HOST_LIKE", "SERVICE_TO_PROCESS_GROUP_LIKE" ]
conditions {
key {
type = "STATIC"
attribute = "SERVICE_TAGS"
}
tag {
# negate = false
operator = "EQUALS"
value {
context = "CONTEXTLESS"
key = "Component"
value = "Buffet"
}
}
}
}
}