[英]Create Resources via terraform
我使用 TERRAFORM 创建了一个 AWS 环境。
之后,一些资源是由控制台(SES、SNS、LAMBDA)创建的,它们不是由 TERRAFORM 提供的。
我正在为控制台创建的这些资源(SES、SNS、LAMBDA)编写 TERRAFORM 代码。
如果我的帐户中已经运行了这些资源,是否可以通过 TERRAFORM 为这些资源生成此代码而不删除它们?
甚至,在这种情况下我该如何处理?
欢迎来到 IaC 的世界,您将大饱眼福。 :)
您可以将在没有 terraform 的情况下创建的所有资源(使用 CLI 或手动配置 - 不属于 tf 状态的资源)导入 terraform state。 导入这些资源后,您就可以开始使用 terraform 管理它们的生命周期。
举个例子:
为了导入现有的非 terraform 托管 lambda,您首先在 your.tf 文件中为其定义资源:
主文件:
resource "aws_lambda_function" "test_lambda" {
filename = "lambda_function_payload.zip"
function_name = "lambda_function_name"
role = "${aws_iam_role.iam_for_lambda.arn}"
handler = "exports.test"
# The filebase64sha256() function is available in Terraform 0.11.12 and later
# For Terraform 0.11.11 and earlier, use the base64sha256() function and the file() function:
# source_code_hash = "${base64sha256(file("lambda_function_payload.zip"))}"
source_code_hash = "${filebase64sha256("lambda_function_payload.zip")}"
runtime = "nodejs12.x"
environment {
variables = {
foo = "bar"
}
}
}
然后可以执行terraform导入,以导入已有的lambda:
terraform import aws_lambda_function.test_lambda my_test_lambda_function
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.