• Modern UX

    Edit and navigate faster in the terminal with Warp's IDE-like input editor.

  • Warp AI

    AI suggests what commands to run and learns from your documentation.

  • Agent Mode

    Delegate tasks to AI and use natural language on the command line.

  • Warp Drive

    Save and share interactive notebooks, workflows, and environment variables.

  • All Features

Delete Kubernetes Deployments With kubectl

Ekene Ejike

Ekene Ejike

Published: 1/31/2024

About Terminus

In kubernetes, Deployments are used to manage, create or modify an instance of a Pod that runs a containerized application. There are several reasons why you need to delete a deployment and you can easily interact with these deployments using the kubectl get  command.

The short answer

In kubernetes, to delete a Deployment, you can use the kubectl delete  command as follows:

$ kubectl delete deployment <deployment>

Where:

  • deployment  is the name of the deployment you want to delete.

Easily retrieve this command using Warp’s AI Command Suggestions

If you’re using Warp as your terminal, you can easily retrieve this command using the Warp AI Command Suggestions feature:

Entering k8s delete deployment  in the AI Command Suggestions will prompt an kubectl  command that can then quickly be inserted into your shell by doing CMD+ENTER .

Deleting all Deployments

To delete all the Deployments in a Kubernetes cluster at once, you can use the kubectl delete  command with the --all  flag as follows:

$ kubectl delete deployment --all

Deleting a Deployment in a namespace

To delete a Deployment in a namespace, you can start by first listing all the Deployments in your Kubernetes cluster using the kubectl get  command with the -A  flag (short for --all-namespaces ):

$ kubectl get deployment -A

Then use the kubectl delete  command with the -n  flag (short for --namespace ) as follows:

$ kubectl delete deployment <deployment> -n <namespace>

Where:

  • deployment  is the name of the deployment you want to delete.
  • namespace  is the name of the sub-cluster that contains this deployment.

Forcing the deletion of a Deployment

Oftentimes, deleting a Deployment forcefully can be useful if you want to start the Deployment afresh or if something went wrong during the initial deployment.

To forcefully delete a Deployment, you can use the --force=true  flag as follows:

$ kubectl delete deployment <deployment> -n <namespace> --force=true

Deleting a Deployment with a grace period

In Kubernetes, the grace period refers to the amount of time given to a Deployment or a Pod to perform any necessary cleanup or shutdown tasks before it is forcefully terminated.

To delete a Deployment with a grace period, you can use the --grace-period  flag as follows:

$ kubectl delete deployment <deployment>--grace-period=<period>

Where:

  • period  is the number of seconds given to a Deployment before being terminated.

For example:

$ kubectl delete deployment my-deployment --grace-period=30

This command will delete the deployment named my-deployment  with a grace period of 30 seconds.

Note that when period  is set to 0 , Kubernetes will immediately terminate the Pods without waiting for them to gracefully terminate. And when set to -1 , Kubernetes will use the default grace period defined in the terminationGracePeriodSeconds  property in the Pod specification.

Deleting a Deployment using a YAML or JSON file

To delete a Deployment based on the YAML or JSON manifest it was created from, you can use the -f  flag (short for --filename ) as follows:

$ kubectl delete -f <file>

Where:

  • file  is the path to the YAML or JSON file containing the Deployment's configuration.

Note that before running this command, you should carefully review the content of the file to avoid unintended deletions of the other resources it may contain.

Deployment using a Kustomization file

In Kubernetes, a Kustomization file is a YAML file that allows you to define and manage multiple resources without modifying the original configuration file.

To delete a Deployment created from a Kustomization file, you can use the -k  flag (short for --kustomize ) as follows:

$ kubectl delete -k <directory>

Where:

  • directory  is the name of the directory that contains the Kustomization file.

Deleting a Deployment and its associated Pods

To delete a Deployment and all the Pods associated with it, you can first scale down the Deployment to prevent the Pods from spawning up again after deletion using the kubectl scale command:

$ kubectl scale --replicas=0 deployment/<deployment> -n <namespace>

Where:

  • replicas  is used to set the number of Pod replicas to 0.

After the Deployment has been scaled down to zero, you can delete all the Pods in a specified namespace using the --all  flag as follows:

$ kubectl delete pod --all -n <namespace>

Finally, you can delete the Deployment itself using the following command:

$ kubectl delete deployment <deployment> -n <namespace>

You can learn more about deleting Pods with our article on how to delete Kubernetes Pods using the kubectl command.

Deleting a Deployment and its associated Services

To delete a Deployment and the Services associated with it, you can first list out the services specific to the Deployment using the kubectl get  command with the --namespace  flag as follows:

$ kubectl get service -n <namespace>

Then, you can delete all the Services using the --all  flag as follows:

$ kubectl delete service --all -n <namespace>

Finally, you can delete the Deployment itself using the following command:

$ kubectl delete deployment <deployment> -n <namespace>

Written by

Ekene Ejike

Ekene Ejike

Filed Under

Related Articles

Copy Files From Pod in Kubernetes

Learn how to copy files and directories from within a Kubernetes Pod into the local filesystem using the kubectl command.

Kubernetes
Razvan Ludosanu

Scale Deployments in Kubernetes

Learn how to manually and automatically scale a Deployment based on CPU usage in Kubernetes using the kubectl-scale and kubectl-autoscale commands.

Kubernetes
Razvan Ludosanu

Get Kubernetes Logs With kubectl

Learn how to get the logs of pods, containers, deployments, and services in Kubernetes using the kubectl command. Troubleshoot a cluster stuck in CrashloopBackoff, ImagePullBackoff, or Pending error states.

Kubernetes
Ekene Ejike

Forward Ports In Kubernetes

Learn how to forward the ports of Kubernetes resources such as Pods and Services using the kubectl port-forward command.

Kubernetes

Tail Logs In Kubernetes

Learn how to tail and monitor Kubernetes logs efficiently to debug, trace, and troubleshoot errors more easily using the kubectl command.

Kubernetes

Get Context In Kubernetes

Learn how to get information about one or more contexts in Kubernetes using the kubectl command.

Kubernetes

Delete Kubernetes Namespaces With kubectl

Learn how to delete one or more namespaces and their related resources in a Kubernetes cluster using the kubectl command.

Kubernetes

Get Kubernetes Secrets With kubectl

Learn how to list, describe, customize, sort and filter secrets in a Kubernetes cluster by name, type, namespace, label and more using the kubectl command.

Kubernetes
Mansi Manhas

List Kubernetes Namespaces With kubectl

Learn how to list, describe, customize, sort and filter namespaces in a Kubernetes cluster by name, label, and more using the kubectl command.

Kubernetes
Mansi Manhas

How To List Events With kubectl

Learn how to list and filter events in Kubernetes cluster by namespace, pod name and more using the kubectl command.

Kubernetes
Mansi Manhas

Kubernetes vs Docker: The Backbone of Modern Backend Technologies

Lean the fundamentals of the Kubernetes and Docker technologies and how they interplay with each other.

KubernetesDocker
Gabriel Manricks

Set Context With kubectl

Learn how to create, modify, switch, and delete a context in Kubernetes using the kubectl config command.

Kubernetes
Mansi Manhas

Trusted by hundreds of thousands of professional developers

Download Warp to get started

Download for Mac