在回答了我在本书出版后收到的问题之后,今天我想解决有关存储库结构的无休止争议,以及一些问题及其解决方案。我将在这里使用基于Terraform的IaC,但在大多数情况下,它也将适用于其他技术。
对于基础结构存储库,有两种完善的选择:
- Monorepo。一个存储库来管理所有内容。包含您所有的IaC,模块和任何辅助自动化;
- 分布式“独立”存储库。包含您提供的解决方案所需的组件。它们可以链接到其他存储库以获取可重用的组件或可变数据。
IaC . , , . , , , , .
, , — . , .
Jaana Dogan . ( ), , . , , , . , , infra-as-code ( , , , ):
- «» « ». , terraform VPC , . , .
- + 1. , . « » « ».
- . Terraform, Ansible, Puppet Kubernetes . , , , , .
- , . Jaana, «» , . , . , . , — — , .
- . . . , «» , , .
«» .
X vs Y, :
— , — .
, , , .
( )
git submodules terraform — , , \\, , , - , . . - — , — - .
- , — , . — , , . provider-module.tf
, \. — Terragrunt .
«»
.
, « »? ! git , ? ! , , ? , , .
— . — , . — , . , - — , . , .
?
, ,
, \\ DevOps\SRE\\\\< >, , ( , , -, ...) , . , — . , ( «» , ) . , , .
git , , . , 1.0.234
, — .
PR
, . , . — . , review approval , , , .
? , , , , , - ? , , .
- terraform, ELB, . , . , . : , , , .
: , , , Terraform Docs — .
, , , « ». , , , .
1: +
- , . . , , «» , .
«» , . , — . , .
, , , :
module "ecr_<repo_name>" {
source = "git::ssh://<repository/terraform-modules.git//ecr?ref=stable"
environment = var.environment
name = "<repo_name>"
}
, , . review, , . , .
2: Monorepo «»
\\ master develop, prod non-prod . , , .
. «»-«». — . , « », . .
, , .
, — « » « », , .