Kustomize

简介

Kustomize 是一种 Kubernetes 原生的配置管理工具,允许用户通过 overlay 和 composition 自定义 Kubernetes 资源定义(YAML 文件),而无需直接修改原始文件。

Kustomize 的核心概念

  • Base:包含通用 Kubernetes 资源定义的基础配置。
  • Overlay:用于修改 Base 配置的自定义层。
  • kustomization.yaml:定义资源如何组合和修改的配置文件。

Argo CD 与 Kustomize 的集成通过支持声明式持续交付增强了 GitOps 实践。示例:

apiVersion: argoproj.io/v1alpha1
kind: Application
metadata:
  name: kustomize-example
spec:
  project: default
  source:
    path: examples/helloWorld
    repoURL: 'https://github.com/kubernetes-sigs/kustomize'
    targetRevision: HEAD
  destination:
    namespace: default
    server: 'https://kubernetes.default.svc'

如果在 repoURLpath 位置存在 kustomization.yaml 文件,Argo CD 将使用 Kustomize 渲染 manifests。

Kustomize 支持以下配置选项:

  • namePrefix:附加到 Kustomize 生成的资源名称前缀。
  • nameSuffix:附加到 Kustomize 生成的资源名称后缀。
  • images:Kustomize image 覆盖列表。
  • replicas:Kustomize replica 覆盖列表。
  • commonLabels:添加到所有资源的标签映射。
  • labelWithoutSelector:布尔值,用于定义 common labels 是否应应用于资源选择器和模板。
  • forceCommonLabels:布尔值,允许覆盖现有标签。
  • commonAnnotations:添加到所有资源的注解映射。
  • namespace:Kubernetes 资源命名空间。
  • forceCommonAnnotations:布尔值,允许覆盖现有注解。
  • commonAnnotationsEnvsubst:布尔值,启用注解值中的环境变量替换。
  • patches:支持内联更新的 Kustomize patch 列表。
  • components:Kustomize component 列表。

要将 Kustomize 与 overlay 一起使用,请将路径指向 overlay 目录。

优势

  • 声明式配置:使用 YAML 文件(通过 kustomization.yaml)定义资源组合和修改。

  • 无模板:通过 patch 和 overlay 自定义配置,无需模板引擎。

  • Kubernetes 原生集成:Kustomize 已内置于 kubectl 中,无需额外工具。

使用场景

  • 多环境分发:通过 Base 和 Overlay 实现环境特定配置(例如应用、集群)。

  • 配置复用:适用于在多个项目之间复用基础配置。

  • 渐进式交付:通过 patch 逐步调整资源配置。

参考

有关更详细的信息,请参阅:Kustomize