6

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

我已经在 C 驱动器中安装了 Terraform,并且下面的脚本存在于同一文件夹 C:/Terraform/userdata.sh、C:/Terraform/main.tf 中,我尝试将路径作为 ${file("./userdata.sh") }" 但它仍然不起作用。

请建议,因为我刚刚学习 terraform。谢谢。

#!/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"
}
} 
4

1 回答 1

9

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

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

此外,作为一项建议,我建议您尝试在脚本中创建一个日志文件,以检查所有步骤已执行。了解脚本是否完全运行也会对您有所帮助。

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

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

希望这可以帮助。

于 2018-08-17T01:03:02.140 回答