In Kubernetes, Pods create a shared environment for one or more containerized application. This shared environment allows containers to communicate and share common resources easily.
The short answer
To display the detailed information of a single Pod, you can use the kubectl describe pod command followed by the name of the Pod:
$ kubectl describe pod <pod_name>
For example:
$ kubectl describe pod my-pod
Upon execution, the above command will output verbose details about the Pod, such as its status, IP address, associated namespace, ports, events, the status of the containers running within it, and more. These comprehensive details are helpful when debugging or troubleshooting any potential issues with your running Pod.
You can learn more about troubleshooting Pods in Kubernetes by reading our article on how to get the logs of Pods using the kubectl command.
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 k8 describe pod in the AI Command Suggestions will prompt a kubectl command, which can be inserted quickly into your shell by doing CMD+ENTER.
Describing Pods in a namespace
To describe a pod in a specified namespace, you can use the kubectl describe pod command with the -n flag (short for --namespace ):
$ kubectl describe pod <pod_name> -n <namespace>
For example:
$ kubectl describe pod my-pod -n my-namespace
Note that, if you attempt to describe a Pod that does not exist in the specified namespace, the command will result in an error, indicating that the Pod does not exist.
Describing all Pods at once
To describe all the pods in your cluster at once, you can use the following command:
$ kubectl describe pods
Upon execution, the above command will provide details for every pod within your cluster. This will help you see the status of all pods at once, making it easier to check their overall health instead of going through them individually.
Understanding the output of the kubectl describe pod command
While the kubectl describe pod command displays extensive information about Pods, its output can be quite overwhelming to navigate.
Here’s a breakdown of the essential information provided by this command.
Main Pod information
The first section contains general information about the Pod itself.
Where:
- Name is the unique name of the Pod.
- Namespace is the namespace the Podis associated with.
- Priority specifies the preference for pod execution by the Kubernetes scheduler.
- Service Account is the pod identity used for accessing cluster resources.
- Node represents a virtual or physical machine where the Pod is executed.
- Start Time is the timestamp of the Pod creation.
- Labels are user-defined key-value pairs used to identify the Pod.
- Annotations are additional metadata for the Pod.
- Status is the current execution status of the Pod.
- IP is the IP address of the Pod.
Understanding the Pod status
The Pod Status property gives an immediate overview of the Pod’s current health.
It takes 5 possible values:
- Pending : the Pod is created, but its containers are not yet ready to run.
- Running : the Pod is actively running on the node, with at least one container in a running state.
- Succeeded : all containers in the Pod have terminated successfully (with an exit status of 0 ).
- Failed : one or more containers within your Pod have terminated with a non-zero exit status, signifying an error.
- Unknown : the state of the Pod cannot be determined, and is typically temporary due to node failures or network issues.
Note that, if a Pod gets stuck in a status different from Running for a long period of time, this might indicate that there is a potential issue with the functioning of the Pod.
Also note that, if the Pod gets stuck in the Pending state, it cannot be scheduled on a node due to insufficient resources. You can use the official guide for debugging pods and debugging running pods to identify the bottleneck issues of your Pod.
The Containers section
The Containers section provides detailed information about the containers running within the Pod, such as their current status and configuration.
Containers running within Pods can be in three different states:
- Waiting : the container is not yet running due to some initial setup or readiness checks.
- Running : the container is actively running.
- Terminated : the container has finished executing and has exited, either successfully or due to a failure that caused its termination.
The Conditions section
The Conditions section provides information about a list of conditions a Pod has passed (or not), each of which describes a specific aspect of the Pod's state.
Some of the most common conditions are:
- Initialized which indicates whether all init containers have completed successfully.
- Ready which indicates whether the Pod is fully operational and is able to serve requests.
- ContainersReady which indicates whether all containers in the Pod are ready and able to accept traffic.
- PodScheduled which indicates whether the Pod has been scheduled to run on a node.
You can learn more about conditions on the official documentation page.
The Events section
The Events section provides a chronological log of events and activities related to your Pod. Common types of events include pod scheduling, container start, image pulling, and so on.
Each log usually contains 5 properties:
- Type: the type of event like Normal , Warning , or Error .
- Reason: a brief code describing the event (e.g. Pulling, Created).
- Age: the time when the event occurred.
- From: the component responsible for logging the event.
- Message: the detailed description of the event.
These events will help identify failures in your running Pod. For example, if a container within a Pod cannot start, the Reason will be set to ContainerCannotRun and accompanied by the additional context in the Message property.
Describing a Pod using a configuration file
To describe a Pod using a YAML or JSON file containing the pod’s configuration, you can use the kubectl describe pod command with the -f flag:
$ kubectl describe -f <path>
Where:
- path is the relative or absolute path of the Pod's configuration file.
For example:
$ kubectl describe -f ./myPodConfiguration.yaml
This command will display all the details of your Pod, such as its status, the status of containers running within it, IP address, associated namespace, ports, events, and more (similar to the kubectl describe pod command).
Describing a Pod using YAML and JSON
By default, the kubectl describe pod command doesn’t provide an option to output the information in YAML or JSON format.
To do so, you can use the kubectl get pods command instead with the -o flag, followed by the name of the desired format:
$ kubectl get pods <pod_name> -o <format>
Where:
- format is either yaml or json .
For example:
$ kubectl get pod my-pod -o yaml
The above command displays the pod information in YAML format, including details about the Pod, its containers, status, and more.
Written by
Mansi Manhas
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.
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.
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.
Forward Ports In Kubernetes
Learn how to forward the ports of Kubernetes resources such as Pods and Services using the kubectl port-forward command.
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.
Get Context In Kubernetes
Learn how to get information about one or more contexts in Kubernetes using the kubectl command.
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.
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.
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.
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 vs Docker: The Backbone of Modern Backend Technologies
Lean the fundamentals of the Kubernetes and Docker technologies and how they interplay with each other.
Set Context With kubectl
Learn how to create, modify, switch, and delete a context in Kubernetes using the kubectl config command.