Auto-sync: update nexus workspace

This commit is contained in:
2026-04-29 15:44:38 +08:00
parent b2aadf771a
commit c961c6a394
114 changed files with 4784 additions and 1334 deletions

View File

@@ -5,51 +5,54 @@ tags:
- Terraform
- Terragrunt
- IaC
- DevOps
- CTP
- DevOps
date: 2026-04-14
---
## Source File
- [[raw/Cloud & DevOps/Public-Cloud-Learning-Sessions/03_Terraform/ctp-topic-48-terraform-vs-terragrunt.md]]
- [[Cloud & DevOps/Public-Cloud-Learning-Sessions/03_Terraform/ctp-topic-48-terraform-vs-terragrunt.md]]
## Summary用中文描述
- 核心主题Terraform 与 Terragrunt 的对比选型,涵盖企业级 IaC 实践
- 问题域:多环境配置管理、基础设施代码复用、状态文件管理
- 方法/机制Terraform 作为核心 IaC 工具云厂商无关Terragrunt 作为 Terraform 的 DRY 封装层,处理跨环境变量和远程状态的重复声明
- 结论/价值:Terraform 与 Terragrunt 命令和语高度一致,但 Terragrunt 通过减少硬编码、提升可复用性来优化大规模企业部署;两者可互补使用
- 核心主题Terraform 与 Terragrunt 的深度对比分析,帮助工程师在战略设计层面和开发调试层面理解两者的差异与适用场景
- 问题域:IaC 工具选型、多云环境管理、企业级 Terraform 状态管理
- 方法/机制Terraform 由 HashiCorp 开发的 Golang 应用通过状态文件将期望状态绑定到实际环境Terragrunt 作为 Terraform 的轻量级包装器,践行 DRY 原则,通过模板化管理 provider 和 remote state 块,避免多环境重复声明
- 结论/价值:两者命令和语高度一致,但定位不同——Terraform 保持云无关的核心能力Terragrunt 优化跨环境的可复用性和配置 DRY
## Key Claims用中文描述
- TerraformHashiCorp 出品)通过状态文件将期望状态与现有环境绑定,企业级使用须将状态文件存在安全可访问的位置
- Terragrunt 是 Terraform 的轻量封装,贯彻 DRY 原则,通过管理 provider 和 remote_state 块减少跨环境重复声明
- Terraform Enterprise 提供带 workspace 的 CI 平台Gruntwork 提供预建可定制模块Atlantis 实现 Git 驱动的自动化部署
- tfsec 用于静态代码安全分析Terratest 用于基础设施测试自动化
- TerraformHashiCorp 开发,通过状态文件将基础设施的期望状态与实际运行环境绑定,企业级使用须将状态文件存在安全可访问的位置
- Terragrunt 是 Terraform 的轻量包装器,践行 DRY 原则, provider 和 remote state 配置抽取为可复用模板,避免跨多环境重复硬编码
- Terraform 与 Terragrunt 在命令和语言层面高度一致Terragrunt plan 即 Terraform planHCL 语法完全兼容
- Terraform Enterprise 提供 CI 平台和 workspacesGruntwork 提供预构建可定制模块和原生 AWS landing zone 方案
- Atlantis 将 Terraform 与 GitHub 深度集成,实现 Pull Request 驱动的自动化基础设施部署
## Key Quotes
> "Terraform ties the desired state to the existing environment using a state file. For enterprise-scale use, storing this file in a safe, accessible location is crucial." — Bob, AWS Solutions Architect
> "Terragrunt offers a way to use information in a repeatable way without hard coding values." — Bob
> "All Terraform commands work with Terragrunt; a Terraform plan becomes a Terragrunt plan." — Bob
> "To run Terraform consistently, it ties the desired state to the existing environment using a state file." — Terraform 状态管理的核心机制说明
> "Terragrunt offers a way to use information in a repeatable way without hard coding values." — Terragrunt 践行 DRY 原则的核心价值
> "Terraform's core is cloud-agnostic, while its vendor-specific parts require separate modules for each cloud provider." — Terraform 厂商相关性的局限
## Key Concepts
- [[Infrastructure As Code]]:通过代码定义和版本控制基础设施资源的实践
- [[DRY Principle]]Don't Repeat Yourself — 避免重复配置,通过抽象层复用
- [[State File Management]]Terraform 状态文件绑定期望状态与实际环境
- [[IaC Testing]]Terratest 等工具对基础设施代码进行自动化测试
- [[InfrastructureAsCode]]:通过代码定义和管理基础设施,实现版本控制和自动化部署
- [[DrYPrinciple]]Don't Repeat YourselfTerragrunt 的核心理念,通过模板复用减少配置重复
- [[TerraformState]]Terraform 通过状态文件将代码定义的期望状态与实际运行环境绑定
- [[Terragrunt]]Terraform 的轻量包装器,优化多环境配置管理
## Key Entities
- [[HashiCorp]]Terraform 创立公司,提供多云基础设施编排工具
- [[Gruntwork]]:提供预建可定制的 Terraform 模块和 Terraform 原生 AWS Landing Zone
- [[Atlantis]]:将 Terraform 与 GitHub 集成的开源 CI/CD 工具
- [[Terraform]]:云厂商无关的基础设施即代码工具
- [[Terragrunt]]Terraform 的 DRY 封装层,管理多环境配置
- [[HashiCorp]]Terraform 的创始公司,开发和维护 Terraform 核心产品
- [[Gruntwork]]:提供预建 Terraform 模块和 AWS landing zone 方案的 SaaS 平台
- [[Atlantis]]开源工具,将 Terraform 与 GitHub/GitLab 集成,实现 PR 驱动的 IaC 自动化
- [[TerraformEnterprise]]HashiCorp 提供的 Terraform 企业版,包含 CI 平台和 workspace 功能
## Connections
- [[Terraform]] ← uses ← [[State File Management]]
- [[Terragrunt]] ← wraps ← [[Terraform]]
- [[Terraform]] ← provided_by ← [[HashiCorp]]
- [[Gruntwork]] ← provides_modules_for ← [[Terraform]]
- [[Atlantis]] ← integrates_with ← [[Terraform]]
- [[Terraform]] ← related_concept ← [[Infrastructure As Code]]
- [[Gruntwork]] ← uses ← [[Terraform]]
- [[Gruntwork]] ← uses ← [[Terragrunt]]
- [[Atlantis]] ← extends ← [[Terraform]]CI/CD 集成)
- [[TerraformEnterprise]] ← is_enterprise_version_of ← [[Terraform]]
## Contradictions
- 暂无发现与其他 Wiki 页面的直接冲突
- 无已知冲突内容
## Related Pages
- [[CTP Topic 9 CI CD with Gruntwork]] — Gruntwork 在 CI/CD 中的实际应用
- [[CTP Topic 32 Using Atlantis CICD for Infrastructure Deployments]] — Atlantis 集成详解
- [[CTP Topic 16 Cross-account Terraform modules]] — 跨账户 Terraform 模块管理