i具有工作的TF设置,可以旋转Azure中的多个Linux VM。我正在Null_Resource中运行本地证明器,以执行Ansible Playbook。我正在从TF状态文件中提取私有IP地址。状态文件是在本地存储的。
我最近配置了Azure后端,现在状态文件存储在存储帐户中。
我已经修改了本地供应商,并且正在尝试获取所有私人IP地址以运行Ansible Playbook,如下所示:
resource "null_resource" "Ansible4Ubuntu" {
provisioner "local-exec" {
command = "sleep 20;ansible-playbook -i '${element(azurerm_network_interface.unic.*.private_ip_address, count.index)}', vmlinux-playbook.yml"
我也尝试了:
resource "null_resource" "Ansible4Ubuntu" {
provisioner "local-exec" {
command = "sleep 20;ansible-playbook -i '${azurerm_network_interface.unic.private_ip_address}', vmlinux-playbook.yml"
它们都只能与第一个VM一起工作,并且忽略其余的。我也尝试过count.index+1 and self.private_ip_address
,但没有运气。
实际结果:TF仅向Ansible提供第一个VM的私有IP。
预期结果:TF向Ansible提供所有私人IP的列表,以便它可以与所有剧本一起运行剧本。
ps:我还在考虑使用TF的远程_STATE数据结构,但似乎状态文件也包含了以前构建中的IP,因此很难提取对当前构建的好处。
我感谢任何帮助。
谢谢Asghar
正如马特(Matt(所说,null_resource仅运行一次,因此它可以与第一个VM一起使用,而忽略其余的。您需要使用NIC列表为NULL_RESOURCE配置触发器,以使其多次运行。这样的示例代码:
resource "null_resource" "Ansible4Ubuntu" {
triggers = {
network_interface_ids = "${join(",", azurerm_network_interface.unic.*.id)}"
}
provisioner "local-exec" {
command = "sleep 20;ansible-playbook -i '${join(" ", azurerm_network_interface.unic.*.private_ip_address)}, vmlinux-playbook.yml"
}
}
您可以根据需要更改其中的东西。有关信息,请参见Null_Resource。