服务器列表的 Cloudwatch 警报
Cloudwatch alarm for list of servers
我正在尝试在服务器列表中设置一些警报,我的服务器在本地定义如下:
locals {
my_list = [
"server1",
"server2"
]
}
然后我这样定义了我的 cloudwatch 警报:(这是一个这样的警报)
resource "aws_cloudwatch_metric_alarm" "ec2-high-cpu-warning" {
for_each = toset(local.my_list)
alarm_name = "ec2-high-cpu-warning-for-${each.key}"
comparison_operator = "GreaterThanThreshold"
evaluation_periods = "1"
metric_name = "CPUUtilization"
namespace = "AWS/EC2"
dimensions = {
instanceid = values(data.aws_instances.my_instances)[*].ids
instancename = local.my_list
}
period = "60"
statistic = "Average"
threshold = "11"
alarm_description = "This warning is for high cpu utilization for ${each.key}"
actions_enabled = true
alarm_actions = [data.aws_sns_topic.my_sns.arn]
insufficient_data_actions = []
treat_missing_data = "notBreaching"
}
我也是这样定义数据源的:
data "aws_instances" "my_instances" {
for_each = toset(local.my_list)
instance_tags = {
Name = each.key
}
}
现在当我 运行 terraform 计划时我得到一个错误:
| data.aws_instances.my_instances is object with 2 attributes
属性“维度”的值不合适:元素“instanceid”:字符串
必填。
在你的 for_each
你应该使用 data.aws_instance.my_instances
:
resource "aws_cloudwatch_metric_alarm" "ec2-high-cpu-warning" {
for_each = data.aws_instance.my_instances
alarm_name = "ec2-high-cpu-warning-for-${each.key}"
comparison_operator = "GreaterThanThreshold"
evaluation_periods = "1"
metric_name = "CPUUtilization"
namespace = "AWS/EC2"
dimensions = {
instanceid = each.value.id
instancename = each.key
}
period = "60"
statistic = "Average"
threshold = "11"
alarm_description = "This warning is for high cpu utilization for ${each.key}"
actions_enabled = true
alarm_actions = [data.aws_sns_topic.my_sns.arn]
insufficient_data_actions = []
treat_missing_data = "notBreaching"
}
以上将为您的两个实例创建两个警报(每个实例一个警报),其中 instancename
将是 server1
或 ``server2`。
我正在尝试在服务器列表中设置一些警报,我的服务器在本地定义如下:
locals {
my_list = [
"server1",
"server2"
]
}
然后我这样定义了我的 cloudwatch 警报:(这是一个这样的警报)
resource "aws_cloudwatch_metric_alarm" "ec2-high-cpu-warning" {
for_each = toset(local.my_list)
alarm_name = "ec2-high-cpu-warning-for-${each.key}"
comparison_operator = "GreaterThanThreshold"
evaluation_periods = "1"
metric_name = "CPUUtilization"
namespace = "AWS/EC2"
dimensions = {
instanceid = values(data.aws_instances.my_instances)[*].ids
instancename = local.my_list
}
period = "60"
statistic = "Average"
threshold = "11"
alarm_description = "This warning is for high cpu utilization for ${each.key}"
actions_enabled = true
alarm_actions = [data.aws_sns_topic.my_sns.arn]
insufficient_data_actions = []
treat_missing_data = "notBreaching"
}
我也是这样定义数据源的:
data "aws_instances" "my_instances" {
for_each = toset(local.my_list)
instance_tags = {
Name = each.key
}
}
现在当我 运行 terraform 计划时我得到一个错误:
| data.aws_instances.my_instances is object with 2 attributes
属性“维度”的值不合适:元素“instanceid”:字符串 必填。
在你的 for_each
你应该使用 data.aws_instance.my_instances
:
resource "aws_cloudwatch_metric_alarm" "ec2-high-cpu-warning" {
for_each = data.aws_instance.my_instances
alarm_name = "ec2-high-cpu-warning-for-${each.key}"
comparison_operator = "GreaterThanThreshold"
evaluation_periods = "1"
metric_name = "CPUUtilization"
namespace = "AWS/EC2"
dimensions = {
instanceid = each.value.id
instancename = each.key
}
period = "60"
statistic = "Average"
threshold = "11"
alarm_description = "This warning is for high cpu utilization for ${each.key}"
actions_enabled = true
alarm_actions = [data.aws_sns_topic.my_sns.arn]
insufficient_data_actions = []
treat_missing_data = "notBreaching"
}
以上将为您的两个实例创建两个警报(每个实例一个警报),其中 instancename
将是 server1
或 ``server2`。