-
Notifications
You must be signed in to change notification settings - Fork 6
/
node-memorypressure.tf
35 lines (31 loc) · 1.49 KB
/
node-memorypressure.tf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
locals {
node_memorypressure_filter = coalesce(
var.node_memorypressure_filter_override,
var.filter_str
)
}
module "node_memorypressure" {
source = "kabisa/generic-monitor/datadog"
version = "1.0.0"
name = "Nodes with Memorypressure"
query = "avg(${var.node_memorypressure_evaluation_period}):max:kubernetes_state.node.by_condition{${local.node_memorypressure_filter} AND condition:memorypressure AND (status:true OR status:unknown)} by {kube_cluster_name,host} > ${var.node_memorypressure_critical}"
alert_message = "Kubernetes cluster node {{node}} has memorypressure. Meaning it is low on memory"
recovery_message = "Kubernetes cluster node {{node}} no longer has Memory Pressure."
# monitor level vars
enabled = var.state_metrics_monitoring && var.node_memorypressure_enabled
alerting_enabled = var.node_memorypressure_alerting_enabled
critical_threshold = var.node_memorypressure_critical
# no warning threshold for this monitor
priority = min(var.node_memorypressure_priority + var.priority_offset, 5)
docs = var.node_memorypressure_docs
note = var.node_memorypressure_note
# module level vars
env = var.env
service = var.service
service_display_name = var.service_display_name
notification_channel = var.notification_channel
additional_tags = var.additional_tags
locked = var.locked
name_prefix = var.name_prefix
name_suffix = var.name_suffix
}