Infra-as-Code Repo策略的优缺点

在回答了我在本书出版后收到的问题之后,今天我想解决有关存储库结构的无休止争议,以及一些问题及其解决方案。我将在这里使用基于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 . , , .





. «»-«». — . , « », . .



, , .



, — « » « », , .




All Articles