Documentation for version v0.50.0 is no longer actively maintained. The version you are currently viewing is a static snapshot. For up-to-date documentation, see the latest version.
Configmap Migration (experimental)
Overview ¶
Kapp internally uses a configmap to store information about an application.
This configmap name has defaulted to the app name supplied during a deploy. kapp deploy -a <app_name>
.
Example:
kapp deploy -a my-app -f app.yml --yes
$ kapp ls
Namespace Name Namespaces Lcs Lca
default my-app default true 7s
$ kubectl get configmaps
NAME DATA AGE
my-app 1 1m
This is challenging when users also want to create a configmap named my-app
for their application. It is not expected that kapp
is already using this configmap name.
Enabling Configmap migration ¶
As of v0.47.0+, kapp now supports a new optional boolean environment variable KAPP_FQ_CONFIGMAP_NAMES
which can be used to migrate both new and existing configmaps to the new naming convention: <app_name>.apps.k14s.io
.
KAPP_FQ_CONFIGMAP_NAMES=true
opts into the new kapp behavior.KAPP_FQ_CONFIGMAP_NAMES=false
maintains the current kapp behavior.
Important Note: The app name is not being changed, only the configmap name, all references to the app name can remain the same.
Examples ¶
Deploy new App ¶
export KAPP_FQ_CONFIGMAP_NAMES=true
kapp deploy -a my-app -f app.yml --yes
$ kapp ls
Namespace Name Namespaces Lcs Lca
default my-app default true 7s
$ kubectl get configmaps
NAME DATA AGE
my-app.apps.k14s.io 1 1m
Deploy existing App ¶
$ kapp ls
Namespace Name Namespaces Lcs Lca
default my-app default true 7s
export KAPP_FQ_CONFIGMAP_NAMES=true
$ kapp deploy -a my-app -f app.yml --yes
$ kubectl get configmaps
NAME DATA AGE
my-app.apps.k14s.io 1 1m
Delete ¶
# With migration enabled
$ KAPP_FQ_CONFIGMAP_NAMES=true kapp delete -a my-app
Changes
Namespace Name Kind Conds. Age Op Op st. Wait to Rs Ri
default simple-app Deployment 2/2 t 28m delete - delete ok -
# With migration disabled
$ KAPP_FQ_CONFIGMAP_NAMES=false kapp delete -a my-app
App 'my-app' (namespace: default) does not exist
Caveats ¶
- Migrated apps will show up with the suffix with previous versions of kapp (0.46.0-):
export KAPP_FQ_CONFIGMAP_NAMES=true
kapp deploy -a my-app -f app.yml --yes
$ kapp ls
Namespace Name Namespaces Lcs Lca
default my-app default true 7s
# With old kapp versions
$ kapp ls
Namespace Name Namespaces Lcs Lca
default my-app.apps.k14s.io default true 7s
Opting out after migration ¶
To return to the previous configmap naming convention, the following steps must be followed:
kubectl get configmap my-app.apps.k14s.io -o yaml > app.yml
Find the
metadata.name
field inapp.yml
and remove the suffix.apps.k14s.io
Find the annotation named
kapp.k14s.io/is-configmap-migrated
inmetadata.annotations
and remove itkubectl create -f app.yml
kubectl delete configmap my-app.apps.k14s.io
Important Note: Ensure the configmap with suffix apps.k14s.io
is deleted after opting-out!
(Help improve our docs: edit this page on GitHub)