Uninstall
If you no longer need your kgateway environment, you can uninstall the control plane and all gateway proxies. You can also optionally remove related components such as Prometheus and sample apps.
Uninstall kgateway
Remove the kgateway control plane and gateway proxies.
-
Get all HTTP routes in your environment.
kubectl get httproutes -A
-
Remove each HTTP route.
kubectl delete -n <namespace> httproute <httproute-name>
-
Get all reference grants in your environment.
kubectl get referencegrants -A
-
Remove each reference grant.
kubectl delete -n <namespace> referencegrant <referencegrant-name>
-
Get all gateways in your environment that are configured by the
gloo-gateway
gateway class.kubectl get gateways -A | grep gloo-gateway
-
Remove each gateway.
kubectl delete -n <namespace> gateway <gateway-name>
-
Uninstall kgateway.
If you installed kgateway in a different namespace than
gloo-system
, include the-n <namespace>
option.glooctl uninstall
ℹ️By default, the
gloo-system
namespace and kgateway CRDs created by theglooctl install
command are not removed. To remove the namespace and CRDs, include the--all
option.glooctl uninstall --all
-
Uninstall the kgateway release.
helm uninstall gloo-gateway -n gloo-system
-
Remove the
gloo-system
namespace.kubectl delete namespace gloo-system
-
-
Remove the Kubernetes Gateway API CRDs.
kubectl delete -f https://github.com/kubernetes-sigs/gateway-api/releases/download/v1.0.0/standard-install.yaml
Uninstall with ArgoCD
For ArgoCD installations, use the following steps to clean up your environment.
-
Port-forward the Argo CD server on port 9999.
kubectl port-forward svc/argocd-server -n argocd 9999:443
-
Open the Argo CD UI.
-
Log in with the
admin
username andkgateway
password. -
Find the application that you want to delete and click x.
-
Select Foreground and click Ok.
-
Verify that the pods were removed from the
gloo-system
namespace.kubectl get pods -n gloo-system
Example output:
No resources found in gloo-system namespace.
-
Port-forward the Argo CD server on port 9999.
kubectl port-forward svc/argocd-server -n argocd 9999:443
-
Log in to the Argo CD UI.
argocd login localhost:9999 --username admin --password kgateway --insecure
-
Delete the application.
argocd app delete gloo-gateway-oss-helm --cascade --server localhost:9999 --insecure
Example output:
Are you sure you want to delete 'gloo-gateway-oss-helm' and all its resources? [y/n] y application 'gloo-gateway-oss-helm' deleted
-
Verify that the pods were removed from the
gloo-system
namespace.kubectl get pods -n gloo-system
Example output:
No resources found in gloo-system namespace.
Uninstall optional components
Remove any optional components that you no longer need, such as sample apps.
-
If you no longer need the Prometheus stack to monitor resources in your cluster, uninstall the release and delete the namespace.
helm uninstall kube-prometheus-stack -n monitoring kubectl delete namespace monitoring
-
Remove the httpbin sample app.
kubectl delete namespace httpbin
-
Remove the Petstore sample app.
kubectl delete -f https://raw.githubusercontent.com/solo-io/gloo/v1.13.x/example/petstore/petstore.yaml