Terraform Local-Exec Provisioner可以在多个Azure虚拟机上运行



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。

最新更新