v3.1.0
Extended patches
Since this version, Kustomize allows applying one patch to multiple resources. This works for both Strategic Merge Patch and JSON Patch. Take a look at patch multiple objects.
Improved Resource Matching
Multiple improvements have been made to allow the user to leverage “namespace” instead/or with “name suffix/prefix” to segregate resources.
Patch resolution improvement
The following example demonstrates how using the namespace field in the patch definition,
will let the user define two different patches against two different Deployment having the
same “deploy1” name but in different namespaces in the same Kustomize context/folder.
Unless the namespace:
field has been specified in the kustomization.yaml, no namespace
value will be handled as Kubernetes default
namespace.
apiVersion: apps/v1
kind: Deployment
metadata:
name: deploy1
namespace: main
spec:
template:
spec:
containers:
- name: nginx
env:
- name: ANOTHERENV
value: TESTVALUE
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: deploy1
namespace: production
spec:
template:
spec:
containers:
- name: main
env:
- name: ANOTHERENV
value: PRODVALUE
Variable resolution improvement
It is possible to add namespace field to the variable declaration. In the following example,
two Service
objects with the same elasticsearch
name have been declared.
Specifying the namespace in the objRef of the corresponding varriables, allows Kustomize to
resovlve thoses variables.
If the namespace is not specified, Kustomize will handle it has a “wildcard” value.
Extract of kustomization.yaml:
vars:
- name: elasticsearch-test-protocol
objref:
kind: Service
name: elasticsearch
namespace: test
apiVersion: v1
fieldref:
fieldpath: spec.ports[0].protocol
- name: elasticsearch-dev-protocol
objref:
kind: Service
name: elasticsearch
namespace: dev
apiVersion: v1
fieldref:
fieldpath: spec.ports[0].protocol
Simultaneous change of names and namespaces
Kustomize is now able to deal with simultaneous changes of name and namespace. Special attention has been paid the handling of:
- ClusterRoleBinding/RoleBinding “subjects” field,
- ValidatingWebhookConfiguration “webhooks” field.
The user should be able to use a kustomization.yaml as shown in the example bellow even if ClusterRoleBind,RoleBinding and ValidatingWebookConfiguration are part of the resources he needs to declare.
Extract of kustomization.yaml:
namePrefix: pfx-
nameSuffix: -sfx
namespace: testnamespace
resources:
...
Resource and Kustomize Context matching
Kustomize is now able to support more aggregation patterns.
If for instance, the top level of kustomization.yaml, is simply combining sub-components, (as in the following example), Kustomize has improved resource matching capabilities. This removes some of the constraints which were present on the utilization of prefix/suffix and namespace transformers in the individual components.
resources:
- ../component1
- ../component2
- ../component3
Other improvements
- Image transformation has been improved. This allows the user to update the sha256 of an image with another sha256.
- Multiple default transformer configuration entries have been added, removing the need for the
user to add them as part of the
configurations:
section of the kustomization.yaml. kustomize
help command has been tidied up.