容器化的日益普及引发了对高效管理、调度和控制Kubernetes(K8s)集群的需求。市场提供了各种与 K8s 环境交互的工具,但没有多少提供能比 Helm
和 Terraform
更多的功能。
本文是Helm
和 Terraform
的主要功能。我们分析了这两种配置工具的优点,解释了它们在管理 K8s 设置方面的能力,并帮助您确定适合您的开发团队的选项。
Terraform 是一种开源基础架构即代码 (IaC)工具,允许团队管理和自动化基础架构、平台和服务。该工具通过代码帮助构建、更改和版本化基础架构,使工程师能够快速轻松地:
2017 年,Terraform 的创建者 Hashicorp 宣布发布其 Kubernetes 提供商。因此,该工具能够根据需要跨多个云提供商管理 K8s 集群。 在配置基础设施或管理 Kubernetes 时,Terraform 依赖于声明性语言。工程师不需要定义设置基础设施的每一步。相反,开发人员提供所需的设置最终状态,并且该工具计划如何配置环境。例如,您可以为 VM、K8s 集群、VPC 和特定防火墙编写一组参数,而无需提供配置说明。
声明性配置文件很有帮助,因为团队可以:
一旦工程师请求配置,命令terraform plan会指示工具比较现有设置并计划如何设置所需的基础设施。然后该terraform apply命令通过云提供商的 API启动资源。Terraform 是DevOps 团队的热门选择,因为工程师可以使用该工具快速启动和编辑CI/CD 管道中的环境。
Helm是一个 Kubernetes 包管理器,非常适合将可重复的应用程序和服务部署到集群。该工具允许用户通过Helm Charts管理应用程序,简化了 K8s 环境的定义、安装和升级。
Helm Charts是转换成 Kubernetes 清单文件的文件和模板包。图表是可重用的,并且可以包含基于 YAML 的模板:
此外,您可以将图表定义为依赖关系或嵌套图表以获得更大的灵活性。管理图表通过单个命令行界面 (CLI) 进行,该功能可简化操作。虽然大多数图表对公众开放,但公司经常编写自定义图表供内部使用。 Helm 有很多好处,包括:
Helm 及其模板引擎非常适合依赖 K8s 资源的CI/CD 流程。工程师无需为每个微服务编辑文件,而是可以定义标准蓝图并使用占位符代替动态值。然后,团队可以使用一个命令创建图表并在不同集群上重新部署相同的应用程序。