Terraform查找并填充AWS cloudwatch警报本身



所以我有一个主要的RDS模块,它引用了另一个名为"cloudwatch_alarms";。

  • 现在,在ONE RDS模块下。。。我有大约6个cloudwatch报警器,它们都引用了"一";cloudwatch_alarms";单元

  • 我面临的问题是:现在每个警报器都有自己的配置。例如,alarmA的阈值为15000,alarmB的阈值为25000。我希望我的代码是;阈值";每个警报本身的值-因为每个警报的每个值都不同-我不能在变量.tf.中对其进行硬编码

  • 我想让地形本身发挥价值。

我在4个不同的环境中使用这个相同的模块,并且每个环境中的每个警报都有不同的"警报";阈值";价值观所以我不能为它保留一个值。因此,我希望我的代码以一种可变地形自动获取每个警报值的方式进行更改(来自AWS(。

有办法做到这一点吗?

我的模块如下:

主.tf模块RDS的一部分:

...
...
module "alarmA" {
source = "git@github.com:cloudwatch_alarms"
alarm_description        = "xxx"
alarm_name               = "${var.name}-alarmA"
comparison_operator      = "LessThanOrEqualToThreshold"
evaluation_periods       = 4
namespace                = "AWS/RDS"
notification_topic       = [var.notification_topic]
period                   = 6
threshold                = 15000
}
module "alarmB" {
source = "git@github.com:cloudwatch_alarms"
alarm_description        = "xxxx"
alarm_name               = "${var.name}-alarmB"
comparison_operator      = "GreaterThanOrEqualToThreshold"
evaluation_periods       = 5
namespace                = "AWS/RDS"
notification_topic       = [var.notification_topic]
period                   = 7
threshold                = 25000
}

cloudwatch_alarms:模块主.tf的一部分

resource "aws_cloudwatch_metric_alarm" "alarm" {
count = var.alarm_count
alarm_description   = var.alarm_description
alarm_name          = var.alarm_count > 1 ? format("%v-%03d", local.alarm_name, count.index + 1) : local.alarm_name
alarm_actions       = []
comparison_operator = var.comparison_operator
datapoints_to_alarm = var.datapoints_to_alarm
dimensions          = var.dimensions[count.index]
evaluation_periods  = var.evaluation_periods
metric_name         = var.metric_name
namespace           = var.namespace
period              = var.period
statistic           = var.statistic
threshold           = var.threshold
unit                = var.unit

cloudwatch_alwarms:的variable.tf

variable "threshold" {
description = "The value against which the specified statistic is compared."
type        = string
}

假设我对您的问题的理解是正确的,您不能在地形中引用现有的AWS警报,因为它没有为警报提供数据源。TF提供的唯一来源是aws_cloudwatch_log_groupaws_cloudwatch_event_source。为了克服这一点,您必须使用例如bash中的AWS CLI来开发自己的外部数据源,如链接的TF文档中所示。

但是,如果这些警报是子模块outputs,则可以在父模块中引用它们。为此,您必须将子模块修改为output,即每个警报的阈值。然后,在父模块中,您可以简单地获取这些输出值,并将它们用于其他目的,例如将它们传递给其他子模块。

相关内容

  • 没有找到相关文章

最新更新