Kustomize 通过对原始资源集进行一系列转换来创建新资源。Kustomize 提供以下默认的 transformers :
- annotations
- images
- labels
- name reference
- namespace
- prefix/suffix
- variable reference
transformer 配置的 fieldSpec
列表,用来确定哪些资源类型和这些类型的 transformer 可以修改哪些字段。
FieldSpec 是一种表示资源中字段路径的类型。
group: some-group
version: some-version
kind: some-kind
path: path/to/the/field
create: false
如果 create
设置为 true
,表示如果尚未找到该路径,则 transformer 将在资源中创建该路径。这对于 label 和 annotation 转换器最有用,因为在转换之前可能未设置 label 或 annotation 的路径。
默认的 images transformer 会更新包含 containers
和 initcontainers
子路径的路径中找到的指定镜像的键值 。如果找到,则更新 image
的 newName
,newTag
和 digest
等字段。该 name
字段应与 image
资源中的键值匹配。
kustomization.yaml 示例:
images:
- name: postgres
newName: my-registry/my-postgres
newTag: v1
- name: nginx
newTag: 1.8.0
- name: my-demo-app
newName: my-app
- name: alpine
digest: sha256:25a0d4
可以通过创建 images
包含 path
和 kind
字段的列表来自定义镜像 transformer 配置。镜像 transformer 教程 展示了如何指定默认镜像 transformer 和自定义镜像 transformer 配置。
prefix/suffix transformer 为所有资源的 metadata/name
字段添加前缀/后缀。默认的 prefix transformer 配置如下:
namePrefix:
- path: metadata/name
kustomization.yaml 示例:
namePrefix:
alices-
nameSuffix:
-v2
labels transformer 将 labels 添加到所有资源的 metadata/labels
字段。它还将 labels 添加到 spec/selector
和 spec/selector/matchLabels
字段以及所有 Deployment 资源中的字段。
示例:
commonLabels:
- path: metadata/labels
create: true
- path: spec/selector
create: true
version: v1
kind: Service
- path: spec/selector/matchLabels
create: true
kind: Deployment
kustomization.yaml 示例:
commonLabels:
someName: someValue
owner: alice
app: bingo
annotations transformer 可以:
- 将 annotations 添加到所有资源的
metadata/annotations
字段 - 将 annotations 添加到Deployment,ReplicaSet,DaemonSet,StatefulSet,Job 和 CronJob 等资源的
spec/template/metadata/annotations
- 将 annotations 添加到CronJob 资源的
spec/jobTemplate/spec/template/metadata/annotations
字段。
kustomization.yaml 示例:
commonAnnotations:
oncallPager: 800-555-1212
Name reference transformer 的配置不同于其他所有的 transformer。nameReferences
列表代表一种可以用作其他类型资源中的引用的所有可能字段。一个 nameReference
包含一个类型如 ConfigMap 以及 fieldSpecs
列表,其中 ConfigMap
其他资源被引用。下面是一个例子:
kind: ConfigMap
version: v1
fieldSpecs:
- kind: Pod
version: v1
path: spec/volumes/configMap/name
- kind: Deployment
path: spec/template/spec/volumes/configMap/name
- kind: Job
path: spec/template/spec/volumes/configMap/name
Name reference transformer 的配置为 nameReferences
列表包含 ConfigMap,Secret,Service,Role和ServiceAccount等资源。下面是一个示例配置:
nameReference:
- kind: ConfigMap
version: v1
fieldSpecs:
- path: spec/volumes/configMap/name
version: v1
kind: Pod
- path: spec/containers/env/valueFrom/configMapKeyRef/name
version: v1
kind: Pod
# ...
- kind: Secret
version: v1
fieldSpecs:
- path: spec/volumes/secret/secretName
version: v1
kind: Pod
- path: spec/containers/env/valueFrom/secretKeyRef/name
version: v1
kind: Pod
除默认 transformers 外,您还可以创建自定义的 transformers 配置。通过调用将默认的 transformers 配置保存到本地目录kustomize config save -d
,然后修改和使用这些配置。本教程显示了如何创建自定义 transformers 配置:
- support a CRD type
- 添加额外的字段以进行变量替换
- 添加额外的字段以供名称参考
metadata:
annotations:
foo.k8s.io/bar: baz
Kustomize 支持在路径中转义特殊字符,例如: metadata/annotations/foo.k8s.io\/bar