user_data中的命令未在terraform中执行

时间:2018-08-16 16:59:08

标签: terraform terraform-provider-aws terraform-template-file

已创建Hi EC2实例,但未执行作为userdata.sh一部分的命令。当我通过腻子手动连接到EC2时,我发现EC2实例中未安装nginx。为了验证脚本是否正在执行,我添加了echo消息,但是当我运行terraform apply时,命令提示符中未显示任何输出。我如何验证用户数据是否正在执行?

我已经在C驱动器中安装了Terraform,并且以下脚本位于同一文件夹C:/Terraform/userdata.sh、C:/Terraform/main.tf中,我尝试给出$ {file(“ ./ userdata。 sh“)}”,但仍然无法正常工作。

请指教,因为我正在学习地形。谢谢。

#!/bin/bash -v
echo "userdata-start"
sudo apt-get update -y
sudo apt-get install -y nginx > /tmp/nginx.log
sudo service nginx start
echo "userdata-end"

这在我的terraform程序[main.tf]中称为如下:

# resource "template_file" "user_data" {
#    template = "userdata.sh"
# }

data "template_file" "user_data" {
template = "${file("userdata.sh")}"
}

resource "aws_instance" "web" {
instance_type = "t2.micro"

ami = "ami-5e8bb23b"

key_name = "sptest"

vpc_security_group_ids = ["${aws_security_group.default.id}"]
subnet_id              = "${aws_subnet.tf_test_subnet.id}"

user_data               = "${data.template_file.user_data.template}"
#user_data              = "${template_file.user_data.rendered}"
#user_data              = "${file("userdata.sh")}"
#user_data              = "${file("./userdata.sh")}"


tags {
Name = "tf-example-ec2"
}
} 

1 个答案:

答案 0 :(得分:5)

我可以看到您发布的代码有一个问题,user_data变量应该像

user_data = "${data.template_file.user_data.rendered}"

此外,作为建议,我建议您尝试在脚本中创建日志文件以检查已执行了所有步骤。知道脚本是否完全运行也将使您受益。

我们代码中的一个示例,您可以根据自己的标准进行修改

logdir=/var/log
logfile=${logdir}/mongo_setup.log
exec >> $logfile 2>&1

希望这会有所帮助。