1

我正在使用 Terraform 在 Azure 云上进行跟踪,

  1. 在 Azure 上创建 RHEL OS VM。
  2. 将 setup.sh 文件复制到新 VM。
  3. 使用远程执行,我正在运行一个 setup.sh 脚本,如下所示。

    provisioner "remote-exec" {
    inline = [
    "chmod +x /home/${var.admin_username}/setup.sh",
    "sudo /home/${var.admin_username}/setup.sh",
    ]
    connection {
    type     = "ssh"
    user     = "${var.admin_username}"
    password = "${var.admin_password}"
    host     = "${azurerm_public_ip.tf-vm-pip.fqdn}"
    }
    }
    

问题:要在新 VM 上运行的脚本需要 root 权限才能执行命令。

我尝试了以下方法,

  1. user = "root" 不起作用,因为我们在 Azure 上没有 root 用户密码。
  2. 在内联块内尝试了 sudo su/sudo -i。

    inline = [
    "chmod +x /home/${var.admin_username}/setup.sh",
    "echo "${var.admin_password}" | sudo -S su",
    "sudo /home/${var.admin_username}/setup.sh",
    ]
    
  3. 修改 shell 脚本,使每个命令都以 sudo 的形式执行,如下所示,

    echo "password" | sudo -S -k cmd1
    echo "password" | sudo -S -k cmd2
    echo "password" | sudo -S -k cmd3....
    

第三种解决方案适用于大多数命令。但由于安全问题不是首选。

有没有办法通过 Azure 云上的 Terraform 以 root 用户身份远程安装脚本?

4

1 回答 1

0

请使用以 root 身份执行脚本的自定义脚本扩展。请在下面找到提及的链接供您参考。 http://hypernephelist.com/2019/06/25/azure-vm-custom-script-extensions-with-terraform.html

于 2020-03-12T10:49:21.117 回答