• 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

Get Context In Kubernetes

Muhammad Khabbab

Published: 3/29/2024

About Terminus

In Kubernetes, a context is a combination of a cluster, a user and a namespace, which defines the operational environment for interacting with a Kubernetes cluster.

The short answer

In Kubernetes, to get concise information about all the existing contexts defined in the kubeconfig  file, such as their cluster name, user name and namespace, you can use the kubectl config  command with the get-contexts  subcommand as follows:

$ kubectl config get-contexts

Once executed, this command will produce an output similar to the following one, where the current context is identified by an asterisk ( * ):

CURRENT   NAME                 CLUSTER          AUTHINFO         NAMESPACE
*         dev-context          dev-cluster      dev-user         development
         staging-context    staging-cluster    staging-user     staging
         prod-context         prod-cluster     prod-user        production

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 list contexts in kubeconfig  in the AI Command Suggestions will prompt a kubectl  command that can then quickly be inserted into your shell by doing CMD+ENTER .

Getting information about the current context

To get information about the current context, you can use the current-context  subcommand as follows:

$ kubectl config current-context

Getting information about a specific context

To get information about a specific context, you can use the get-contexts  subcommand as follows:

$ kubectl config get-contexts <context_name>

Where:

  • context_name  is the name of the context.

For example, the following command will display the information related to the context named staging-context :

$ kubectl config get-contexts staging-context

If you want to learn more about modifying existing contexts in Kubernetes, you can read our other article on how to set a context with kubectl.

Getting comprehensive context overview

To output a comprehensive overview of the kubeconfig  file settings, including information about clusters, users, API servers and more, you can use the view  subcommand as follows:

$ kubectl config view

Note that, by default, this command will output information in the YAML format.

To output it in the JSON format instead, you can use the -o  flag (short for --output ) as follows:

$ kubectl config view -o json

Viewing the details of the current context

To only output the detailed overview of the current context, you can use the --minify  flag as follows:

$ kubectl config view --minify

Viewing the details of a specific context

To only output the detailed overview of a specific context, you can combine the --minify  flag with the --context  flag as follows:

$ kubectl config view --minify --context=<context_name>

Retrieving context properties

To retrieve a particular property from a specific context, you can use the -o jsonpath  flag combined with a JSONPath expression as follows:

$ kubectl config view --minify -o jsonpath='{..<property>}'

Where:

  • property  is the name of the property you want to retrieve (e.g., cluster , user , namespace , etc).

Retrieving the namespace of the current context

To retrieve the namespace of the current context, you can use the aforementioned command with the following JSONPath expression:

$ kubectl config view --minify -o jsonpath='{..namespace}'

Retrieving the namespaces of all contexts

To retrieve the namespaces of all the contexts defined in kubeconfig  file in the form of a list, you can use the aforementioned command with the following JSONPath expression:

$ kubectl config view --minify -o jsonpath='{.contexts[*].context.namespace}'

Alternatively, to also retrieve the name of the context each namespace is associated to, you can use the following for  loop instead:

$ for context in $(kubectl config get-contexts -o name); do
namespace=$(kubectl config view -o jsonpath="{.contexts[?(@.name == \"${context}\")].context.namespace}")
echo "Context: $context, Namespace: ${namespace:-default}"
done

Where:

  • The for  loop iterates over the list of context names returned by the kubectl config get-contexts -o name  command.

  • Retrieves the namespace related to that context using the kubectl config view -o jsonpath="{.contexts[?(@.name == "${context}")].context.namespace}"  command.

  • Outputs the context name and namespace using the echo  command.

Getting information about the resources of a specific context

To get information on a resource type related to a specific context, you can use the kubectl get  command with the --context  flag as follows:

$ kubectl get <resource_type> --context <context_name>

Where:

  • resource_type  is the name of the resource type (e.g., pods , nodes , services , etc).

  • context_name  is the name of the context.

For example, the following command will output information about the Services related to the context named staging-context :

$ kubectl get services --context staging-context

Written by

Muhammad Khabbab

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

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

List Pods With kubectl

Learn how to list and filter Kubernetes Pods by name, namespaces, labels, manifests, and more using the kubectl command.

Kubernetes
Mansi Manhas

Trusted by hundreds of thousands of professional developers

Download Warp to get started

Download for Mac