我正在编写一个地形脚本,用于在 AWS 上创建一个 EKS 集群及其工作节点。第一次这样做,所以我有点困惑。以下是文件夹组织:
├─── Int AWS Account
│ ├─── variables.tf
│ ├─── eks-cluster.tf (refers the modules)
│ ├─── others
│
├─── Prod AWS Account
│ ├─── (will be the same than Int with different settings in variables)
│
├─── ReadMe.md
│
├─── data sources
│
├─── Modules
│ ├─── cluster.tf
│ ├─── worker-nodes.tf
│ ├─── worker-nodes-sg.tf
我对如何使用和传递变量有点困惑。现在,我正在做的是我在模块文件夹中引用 ${var.name},在 eks-cluster.tf 中,我要么输入一个直接值 name = blabla(主要是避免它(,要么再次引用变量并在帐户文件夹中有一个变量文件。
这是对的吗?
我不确定我是否正确理解了您的问题,但总的来说,您希望仅保留带有变量的模块文件,因为模块旨在是通用的,因此您可以轻松地将它们包含在不同的环境中。
将模块包含在eks_cluster_int.tf
或eks_cluster_prod.tf
中时,您将传递模块本身中定义的所有变量的值。这样,您就可以在同一模块中使用特定于环境的值。
module "cluster" {
source = "..."
var1 = value1 # directly passing value
var2 = ${var.int_specific_var} # can be defined in variables.tf of environment
...
}
这回答了你的问题吗?