非常复杂,因为 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 对象了。耶!