Moving Helm release to another Kubernetes Namespace

If you want to cleanup your Helm releases, moving them into more appropriate namespace than the one initially deployed into, you might feel kinda stuck, since Helm CLI does not allow you to move these already deployed release to another namespace. But, it can be accomplished with some manual editing of K8s resources...

Information about Helm v3 release is stored in a secret within a namespace where release is deployed.

These secrets can be carefully updated to "move" release from one namespace to another.

The following moves Helm release, as visible from output of helm ls -n mynamespace command. It does not move any of the K8s resources which are part of the release.

Using Jenkins Helm chart as an example:

  1. reflect on "do I really need to do this?"

  2. get the original secret

    kubectl -n default get secret sh.helm.release.v1.jenkins.v1 -o yaml | neat > jenkins_release_orig.yaml
    
  3. decode the secret's data.release (it's double-base64 encoded, and gzipped)

    oq -i yaml -r '.data.release' jenkins_release_orig.yaml  | base64 -D | base64 -D | gzip -d > jenkins_release_secret_decoded.txt
    
  4. change the namespace of the release, and save the changes into the new file

    NEW_VALUE=$(cat jenkins_release_data_decoded.txt | jq -c '.namespace="jenkins"' | gzip -c | base64 | base64)
    oq -i yaml -o yaml --arg new "$NEW_VALUE" '.data.release = $new' jenkins_release_orig.yaml > jenkins_release_moved.yaml
    
  5. verify and apply

    oq -i yaml -r '.data.release' jenkins_release_moved.yaml | base64 -D | base64 -D | gzip -d | jq .namespace
    kubectl -n jenkins apply -f jenkins_release_moved.yaml
    helm -n default ls
    helm -n jenkins ls
    
  6. remove old release record (secret) in original namespace

    kubectl -n default delete secret sh.helm.release.v1.jenkins.v1
    
  7. rinse and repeat for other versions / deployments of the release

Moving resources to another namespace can be achieved grabbing K8s manifests, modifying them with desired metadata.namespace and redeploying them. It helps to be extra careful with PVs, to avoid loosing them. Whenever possible, consider deleting Helm release, and redeploying it in the new namespace to save yourself a headache.