转换 Openstack v2 DNS 记录以使用 Terraform 获取 FQDN


openstack_v2在使用提供程序的 Terraform 中,处理 DNS 记录

非常复杂,因为 DNS 记录有一个跟踪点,并且无法使用 Terraform (0.11( 轻松处理这些情况。

请参阅第一条评论。起初我没有指定 fqdn 几乎可以在任何地方与尾随点一起使用:浏览器、终端、ansible......此用例是指尾随点导致问题。例如,在处理 fqdn 的系统中...

下面是一个 dns 记录的示例:

module.runners.openstack_dns_recordset_v2.dns-record.0:
  id = b84346ec-240b-4517-8da5-0715ed196bc2/234acad2-909a-490c-8aec-b9655fa4bc41
  description = 
  name = runner-1.dns-zone.domain.net.
  records.# = 1
  records.0 = 192.168.0.57
  region = RegionOne
  ttl = 3000
  type = A
  zone_id = b84346ec-240b-4517-8da5-0715ed196bc2

Terraform 不提供任何转换列表中字符串的方法。我该怎么做?

解决方案是使用可以承载计数值的data_null_source。count 变量是将字符串转换应用于列表值的唯一方法。

下面是处理此用例的代码示例。它将删除每个 dns 记录名称的最后一个字符,允许我们稍后在没有尾随点的情况下使用 FQDN。

data "null_data_source" "fqdns" {
  count = "${var.instance_count}"
  inputs = {
    dns = "${substr(element(openstack_dns_recordset_v2.dns-record.*.name, count.index),0,length(element(openstack_dns_recordset_v2.dns-record.*.name, count.index))-1)}"
  }
}
output "fqdns" {
  value = ["${data.null_data_source.fqdns.*.outputs.dns}"]
}

现在我们可以使用 fqdns 对象了。耶!

最新更新