google-cloud-platform - 多环境 terragrunt gcp 项目的模板?
问题描述
我想开始一个新的 Terraform 项目,该项目将在 GCP 帐户上部署资源。我想使用 Terragrunt 来配置多个环境(测试、开发、产品)。
基本上每个环境都是相同的,只是资源的名称有一个前缀(环境名称)并且资源将在另一个区域中。我也想用 terragrunt 让它保持干燥。
到目前为止,我只有这个所需的文件夹结构:
project
└── env
└── test
└── dev
└── prod
└── resources
└── vpc
└── pubsub
└── cloudrun
└── resource4
我对 Terragrunt 感到困惑,而 Terraform 是压倒性的。我对此几乎没有经验,我主要了解 AWS 上的 CloudFormation。
那么我应该把 terragrunt.hcl 文件放在哪里,里面应该有什么?我在哪里存储资源变量以及如何强制资源使用环境变量(区域和前缀)。我应该使用什么命令来部署特定环境?
解决方案
这是一个简单的例子。Azure 是这里的提供者,但这不会改变模块的组织方式。
这假设您正在使用本地 TF 状态(可能您想要设置远程状态)。
此处还从本地文件系统中引用了模块。您可以将它们存储在单独的 Git 存储库中(Terragrunt 建议的方式)以进行版本控制。
可重用模块示例project/resources/resource_group/main.tf
:
terraform {
required_providers {
azurerm = {
source = "hashicorp/azurerm"
version = "~> 2.26"
}
}
}
resource "azurerm_resource_group" "resource_group" {
name = "${var.project}-${var.environment}-resource-group"
location = var.location
tags = {
project = var.project
environment = var.environment
region = var.location
}
}
# I've included variables and outputs in the same file,
# but it's recommended to put them into separate
# variables.tf and outputs.tf respectively.
variable "project" {
type = string
description = "Project name"
}
variable "environment" {
type = string
description = "Environment (dev / stage / prod)"
}
variable "location" {
type = string
description = "The Azure Region where the Resource Group should exist"
}
output "resource_group_name" {
value = azurerm_resource_group.resource_group.name
}
给定环境中模块的示例用法。模块路径是project/test/resource_group/terragrunt.hcl
:
generate "provider" {
path = "provider.tf"
if_exists = "overwrite_terragrunt"
contents = <<EOF
provider "azurerm" {
features {}
}
EOF
}
terraform {
source = "../../resources//resource_group"
}
inputs = {
project = "myapp"
environment = "test"
location = "East US"
}
要部署该特定模块(与我的示例不同,它可能具有多个资源),您terragrunt apply
从project/test/resource_group
.
terragrunt apply-all
或者,您可以通过从运行来执行多个模块project/test
。
老实说,如果你打算将它用于生产项目,你最好阅读 Terragrunt 文档,它非常好。
推荐阅读
- reactjs - Material ui wrapper - 为给定的 prop 重用 typescript 类型
- emacs - Org Capture:确定目标文件时提示信息
- amazon-web-services - 具有上下文根的 AWS 负载平衡
- c# - 项目中的依赖注入可以被解决方案中的其他项目使用
- java - Apache Spark:java.lang.OutOfMemoryError:Java 堆空间问题
- java - 基于当前值的加权随机性(不知道如何解释)
- shell - 使用 sed 将文本替换为特殊字符
- javascript - 根据范围数组动态过滤对象数组
- bulma - 从 Bulma SASS 中删除未使用的颜色
- sql - 如何从电话号码中删除空格(SQL)