我正在使用Terraform中的IF/ELSE pattern来构建具有或不具有公共IP的NIC。分配NIC时出现问题。我找不到一种技术可以让我选择用于创建NIC的资源(有或没有公共IP)。使用三元操作失败,因为其中一个资源不存在。将资源放在列表中不会进行插值。如何分配正确的资源输出?
resource "azurerm_public_ip" "public_ip" {
count = "${var.assign_public_ip}"
name = "${format("${var.name}-pip%02d", count.index)}"
location = "${var.location}"
resource_group_name = "${var.resource_group_name}"
public_ip_address_allocation = "static"
tags {
environment = "${var.resource_group_name}"
}
}
resource "azurerm_network_interface" "nic_with_public_ip" {
count = "${var.assign_public_ip}"
name = "${format("${var.name}-nic%02d", count.index)}"
location = "${var.location}"
resource_group_name = "${var.resource_group_name}"
ip_configuration {
name = "ip_cfg"
subnet_id = "${var.subnet_id}"
private_ip_address_allocation = "dynamic"
public_ip_address_id = "${azurerm_public_ip.public_ip.id}"
}
}
resource "azurerm_network_interface" "nic" {
count = "${1 - var.assign_public_ip}"
name = "${format("${var.name}-nic%02d", count.index)}"
location = "${var.location}"
resource_group_name = "${var.resource_group_name}"
ip_configuration {
name = "ip_cfg"
subnet_id = "${var.subnet_id}"
private_ip_address_allocation = "dynamic"
}
}
resource "azurerm_virtual_machine" "centos" {
count = "${var.count}"
name = "${format("${var.name}%02d", count.index)}"
location = "${var.location}"
resource_group_name = "${var.resource_group_name}"
network_interface_ids = ["${var.assign_public_ip == 1 ? azurerm_network_interface.nic_with_public_ip.id : azurerm_network_interface.nic.id }"]
vm_size = "${var.size}"
delete_os_disk_on_termination = true
delete_data_disks_on_termination = true
storage_image_reference {
publisher = "OpenLogic"
offer = "CentOS"
sku = "7.3"
version = "latest"
}
storage_os_disk {
name = "${format("${var.name}-osdisk%02d", count.index)}"
caching = "ReadWrite"
create_option = "FromImage"
}
os_profile {
computer_name = "${format("${var.name}%02d", count.index)}"
admin_username = "${var.admin_user}"
}
os_profile_linux_config {
disable_password_authentication = true
ssh_keys = {
path = "/home/${var.admin_user}/.ssh/authorized_keys"
key_data = "${var.ssh_key}"
}
}
tags {
environment = "${var.name}"
}
}
此操作失败,并显示以下错误: 运行计划错误:发生1个错误:
* module.jumphost.azurerm_virtual_machine.centos: 1 error(s) occurred:
* module.jumphost.azurerm_virtual_machine.centos: Resource 'azurerm_network_interface.nic' not found for variable 'azurerm_network_interface.nic.id'
答案 0 :(得分:2)
A" splat表达"可用于获取从count
的资源块创建的实例的属性值列表:
azurerm_network_interface.nic_with_public_ip.*.id
这会在count = 0
时返回一个空列表。在这种情况下,所有计数总共有一个,可以通过concat
利用此选项来选择存在的任何一个:
network_interface_ids = "${concat(azurerm_network_interface.nic_with_public_ip.*.id, azurerm_network_interface.nic.*.id)}"
由于network_interface_ids
已经是一个列表,我们可以直接在此处分配concat
的结果。由于如何在这些资源上分配count
,我们知道此列表将始终只有一个元素,从而实现选择活动元素所需的结果。
答案 1 :(得分:0)
在资源azurerm_virtual_machine
中,更改为azurerm_network_interface.nic.*.id