201 lines
6.2 KiB
HCL
201 lines
6.2 KiB
HCL
#
|
|
# FILTERS
|
|
#
|
|
data "template_file" "filter" {
|
|
template = "$${filter}"
|
|
|
|
vars {
|
|
filter = "${var.filter_tags_use_defaults == "true" ?
|
|
format("project_id:%s",var.project_id) :
|
|
"${var.filter_tags_custom}"}"
|
|
}
|
|
}
|
|
|
|
#
|
|
# MySQL Network Connections
|
|
#
|
|
resource "datadog_monitor" "network_connections" {
|
|
name = "[${var.environment}] Cloud SQL MySQL Network Connections (hard limit: ${var.network_connections_hard_limit}) {{#is_alert}}{{{comparator}}} {{threshold}}% ({{value}}%){{/is_alert}}{{#is_warning}}{{{comparator}}} {{warn_threshold}}% ({{value}}%){{/is_warning}}"
|
|
message = "${coalesce(var.network_connections_message, var.message)}"
|
|
|
|
type = "metric alert"
|
|
|
|
query = <<EOF
|
|
avg(${var.network_connections_timeframe}):
|
|
avg:gcp.cloudsql.database.network.connections{${data.template_file.filter.rendered}}
|
|
by {database_id}
|
|
> ${var.network_connections_threshold_critical}
|
|
EOF
|
|
|
|
thresholds {
|
|
warning = "${var.network_connections_threshold_warning}"
|
|
critical = "${var.network_connections_threshold_critical}"
|
|
}
|
|
|
|
notify_no_data = false
|
|
require_full_window = false
|
|
renotify_interval = 0
|
|
notify_audit = false
|
|
timeout_h = 0
|
|
include_tags = true
|
|
locked = false
|
|
evaluation_delay = "${var.delay}"
|
|
new_host_delay = "${var.delay}"
|
|
silenced = "${var.network_connections_silenced}"
|
|
|
|
tags = [
|
|
"team:gcp",
|
|
"provider:gcp",
|
|
"env:${var.environment}",
|
|
"resource:cloud-sql",
|
|
"engine:mysql",
|
|
"${var.network_connections_extra_tags}",
|
|
]
|
|
}
|
|
|
|
#
|
|
# Replication Lag
|
|
#
|
|
resource "datadog_monitor" "replication_lag" {
|
|
name = "[${var.environment}] Cloud SQL MySQL Replication Lag too high"
|
|
message = "${coalesce(var.replication_lag_message, var.message)}"
|
|
|
|
type = "metric alert"
|
|
|
|
query = <<EOF
|
|
min(${var.replication_lag_timeframe}):
|
|
avg:gcp.cloudsql.database.mysql.replication.seconds_behind_master{${data.template_file.filter.rendered}}
|
|
by {database_id}
|
|
> ${var.replication_lag_threshold_critical}
|
|
EOF
|
|
|
|
thresholds {
|
|
critical = "${var.replication_lag_threshold_critical}"
|
|
warning = "${var.replication_lag_threshold_warning}"
|
|
}
|
|
|
|
notify_no_data = true
|
|
require_full_window = false
|
|
renotify_interval = 0
|
|
notify_audit = false
|
|
timeout_h = 0
|
|
include_tags = true
|
|
locked = false
|
|
evaluation_delay = "${var.delay}"
|
|
new_host_delay = "${var.delay}"
|
|
silenced = "${var.replication_lag_silenced}"
|
|
|
|
tags = [
|
|
"team:gcp",
|
|
"provider:gcp",
|
|
"env:${var.environment}",
|
|
"resource:cloud-sql",
|
|
"engine:mysql",
|
|
"${var.replication_lag_extra_tags}",
|
|
]
|
|
}
|
|
|
|
#
|
|
# Queries Anomaly
|
|
#
|
|
resource "datadog_monitor" "queries_changing_anomaly" {
|
|
count = "${length(var.queries_changing_database_ids)}"
|
|
|
|
name = "[${var.environment}] [${var.queries_changing_database_ids[count.index]}] Cloud SQL MySQL Queries Count changed abnormally {{#is_alert}}{{{comparator}}} {{threshold}}% ({{value}}%){{/is_alert}}{{#is_warning}}{{{comparator}}} {{warn_threshold}}% ({{value}}%){{/is_warning}}"
|
|
message = "${coalesce(var.queries_changing_message, var.message)}"
|
|
|
|
type = "query alert"
|
|
|
|
query = <<EOF
|
|
avg(${var.queries_changing_timeframe}):
|
|
anomalies(
|
|
default(
|
|
avg:gcp.cloudsql.database.mysql.queries{project_id:${var.project_id},database_id:${var.project_id}:${var.queries_changing_database_ids[count.index]}},
|
|
0),
|
|
'${var.queries_changing_anomaly_detection_algorithm}',
|
|
${var.queries_changing_deviations},
|
|
direction='${var.queries_changing_direction}',
|
|
seasonality='${var.queries_changing_seasonality}'
|
|
)
|
|
> ${var.queries_changing_threshold_critical}
|
|
EOF
|
|
|
|
thresholds {
|
|
warning = "${var.queries_changing_threshold_warning}"
|
|
critical = "${var.queries_changing_threshold_critical}"
|
|
}
|
|
|
|
notify_no_data = false
|
|
require_full_window = false
|
|
renotify_interval = 0
|
|
notify_audit = false
|
|
timeout_h = 0
|
|
include_tags = true
|
|
locked = false
|
|
evaluation_delay = "${var.delay}"
|
|
new_host_delay = "${var.delay}"
|
|
silenced = "${var.queries_changing_silenced}"
|
|
|
|
tags = [
|
|
"team:gcp",
|
|
"provider:gcp",
|
|
"env:${var.environment}",
|
|
"resource:cloud-sql",
|
|
"engine:mysql",
|
|
"database_id:${var.project_id}:${var.queries_changing_database_ids[count.index]}}",
|
|
"${var.queries_changing_extra_tags}",
|
|
]
|
|
}
|
|
|
|
#
|
|
# Questions Anomaly
|
|
#
|
|
resource "datadog_monitor" "questions_changing_anomaly" {
|
|
count = "${length(var.questions_changing_database_ids)}"
|
|
|
|
name = "[${var.environment}] [${var.questions_changing_database_ids[count.index]}] Cloud SQL MySQL Questions Count changed abnormally {{#is_alert}}{{{comparator}}} {{threshold}}% ({{value}}%){{/is_alert}}{{#is_warning}}{{{comparator}}} {{warn_threshold}}% ({{value}}%){{/is_warning}}"
|
|
message = "${coalesce(var.questions_changing_message, var.message)}"
|
|
|
|
type = "query alert"
|
|
|
|
query = <<EOF
|
|
avg(${var.questions_changing_timeframe}):
|
|
anomalies(
|
|
default(
|
|
avg:gcp.cloudsql.database.mysql.questions{project_id:${var.project_id},database_id:${var.project_id}:${var.questions_changing_database_ids[count.index]}},
|
|
0),
|
|
'${var.questions_changing_anomaly_detection_algorithm}',
|
|
${var.questions_changing_deviations},
|
|
direction='${var.questions_changing_direction}',
|
|
seasonality='${var.questions_changing_seasonality}'
|
|
)
|
|
> ${var.questions_changing_threshold_critical}
|
|
EOF
|
|
|
|
thresholds {
|
|
warning = "${var.questions_changing_threshold_warning}"
|
|
critical = "${var.questions_changing_threshold_critical}"
|
|
}
|
|
|
|
notify_no_data = false
|
|
require_full_window = false
|
|
renotify_interval = 0
|
|
notify_audit = false
|
|
timeout_h = 0
|
|
include_tags = true
|
|
locked = false
|
|
evaluation_delay = "${var.delay}"
|
|
new_host_delay = "${var.delay}"
|
|
silenced = "${var.questions_changing_silenced}"
|
|
|
|
tags = [
|
|
"team:gcp",
|
|
"provider:gcp",
|
|
"env:${var.environment}",
|
|
"resource:cloud-sql",
|
|
"engine:mysql",
|
|
"database_id:${var.project_id}:${var.questions_changing_database_ids[count.index]}",
|
|
"${var.questions_changing_extra_tags}",
|
|
]
|
|
}
|