Skip to main content
Version: 1.1.0

Uninstall KubeSlice

This topic describes how to uninstall KubeSlice. Follow these steps to uninstall the KubeSlice Controller:

  • Delete the ServiceExport for each application
  • Offboard all namespaces from the slice
  • Delete a slice
  • Uninstall Slice operator
  • Deregister the worker cluster
  • Delete a project
  • Uninstall the KubeSlice Controller

Delete ServiceExports

If a ServiceExport was created in the application namespace, it must be deleted first.

Deleting the ServiceExport removes the corresponding ServiceImport automatically on all the clusters of the slice.

The below variables are required to delete the service export.

VariablesDescription
<cluster name>The name of the cluster the application is deployed on.
<service export name>The name of the service export that you want to delete.
<namespace>The namespace the application is deployed on.

Switch the contexts to the cluster you deployed the application on:

kubectx <cluster name>

Use the following command to delete the ServiceExport from the cluster:

kubectl delete serviceexport <serviceexport name> -n <application namespace>

Offboard Application Namespaces

To offboard the namespace from a slice, delete the namespace and the associated clusters under the applicationNamespaces in the slice configuration file as illustrated below.

  namespaceIsolationProfile:
applicationNamespaces:
- namespace: iperf
clusters:
- '*'
- namespace: bookinfo
clusters:
- '*'

For example, in the above slice configuration YAML file, if you want to offboard the BookInfo namespace from all clusters, edit the slice configuration YAML file and remove it from applicationNamespaces as illustrated below.

namespaceIsolationProfile:
applicationNamespaces:
- namespace: iperf
clusters:
- '*'

To delete a slice, you must remove all the namespaces and the corresponding clusters. So, edit the slice configuration YAML file to remove them. After you remove the namespaces and the corresponding clusters, the application namespace configuration looks as illustrated below.

namespaceIsolationProfile:
applicationNamespaces:

Apply the slice configuration YAML to update the offboarded namespaces.

kubectl apply -f <slice configuration>.yaml -n <project namespace>
success

You have successfully offboarded the namespaces from the slice.

Delete Slices

caution

This step must be completed before uninstalling the Slice Operator. Failing to do so can result in slices and resources not being cleaned up properly.

Switch the context to the controller cluster using the following command:

kubectx <cluster name>

To delete an individual slice, use the following command:

kubectl delete sliceconfig <slice-name> -n kubeslice-<project-name>

To delete all the slices, use the following command:

kubectl delete sliceconfig --all -n kubeslice-<project-name>
success

You have successfully deleted the slice(s).

Uninstall the Slice Operator

caution

You must remove the cluster from all the slices it is connected to before uninstalling the Slice Operator in the worker cluster. Failing to do so can result in slices and resources not being cleaned up properly.

After removing a cluster from all the slices, you can uninstall the Slice Operator in the worker cluster.

Switch the context to the worker cluster using the following command:

kubectx <cluster name>

Uninstall the Slice Operator using the following command:

helm uninstall [RELEASE_NAME] -n kubeslice-system

Delete Slice Operator CRDs

Delete the CRDs of the Slice Operator using the following commands:

kubectl delete crd serviceexports.networking.kubeslice.io
kubectl delete crd serviceimports.networking.kubeslice.io
kubectl delete crd slices.networking.kubeslice.io
kubectl delete crd slicegateways.networking.kubeslice.io

Delete kubeslice-system Namespace

Delete the kubeslice-system namespace using the following command:

kubectl delete ns kubeslice-system
success

You have now uninstalled the Slice Operator from your registered cluster.

Deregister Worker Clusters

After uninstalling the Slice Operator successfully, deregister your worker cluster from the KubeSlice Controller.

Switch the context to the KubeSlice Controller cluster.

kubectx <cluster name>

Deregister a worker cluster using the following command:

kubectl delete clusters <cluster-name> -n kubeslice-<project-name>

To deregister all worker clusters, use the following command:

kubectl delete clusters --all -n kubeslice-<project-name>
success

You have now successfully deregistered the cluster from the KubeSlice Controller.

Delete a Project

caution

Before deleting a project, ensure all namespaces have been offboarded and the slice has been deleted.

Delete a project after deregistering the worker cluster. The service account, namespaces, clusters, secrets, certificates, and tokens are all deleted when the project is deleted from the KubeSlice Controller.

Use the following command to delete the project:

kubeslice-cli delete project <project-name> -n <controller-namespace>

Uninstall the KubeSlice Controller

Uninstall the KubeSlice Controller

Uninstall the KubeSlice Controller using the following command:

helm uninstall kubeslice-controller -n kubeslice-controller

Delete the kubeslice-controller Namespace

Delete the kubeslice-controller namespace using the following command:

kubectl delete ns kubeslice-controller

Delete the Certificate Manager

Delete the Certificate Manager using the following command:

helm uninstall cert-manager -n cert-manager

Delete the Certificate Manager Namespace

Delete the namespace cert-manager using the following command:

kubectl delete ns cert-manager
success

All set! KubeSlice Controller has been uninstalled from your cluster.