Explore your Kubernetes cluster with k9s

If you use Kubernetes, you have probably become adept at crafting commands with kubectl (pronounced “koob-cuddle”). Sure, we prefer to interact with the cluster with declarative configs via a deployment pipeline, but sometimes you need to see what’s going on, right now. Cue the commands, something such as…

$ kubectl config set-context --current --namespace=transaction-api
Context "gke_davidnortonjr_us-central1-c_cluster-1" modified

$ kubectl get pod -o wide
…


$ kubectl describe 

$ kubectl logs 
error: a container name must be specified for pod xxx-yyyy, choose one of: [event-exporter prometheus-to-sd-exporter]


$ kubectl logs  
lots
and
lots
of
verbose
logs

$ kubectl exec -it  -c container name

And so on. kubectl is great and all, but it can get a little wordy. It’s a powerful tool that every person that works with Kubernetes should master. But folks, you should really check out k9s.

k9s is a cross between kubectl and the Kubernetes dashboard. It is command-line based, but with an interactive “curses” UI. You can install the binary anywhere you can install kubectl, and it uses the same configuration and authentication mechanisms. And it is just so great! But don’t take my word for it, check out this short screencast:

What did we just do here?

  1. Verified kubectl was configured to point at a cluster
  2. Opened k9s
  3. List deployments
  4. List namespaces and select a namespace
  5. Scale a deployment
  6. List pods
  7. Sort and filter the pod list
    1. We filtered with plain text
  8. View and filter logs on a container
  9. Shell into a container
  10. Port-forward to a pod
    1. This is handy, if like me you rarely remember which port a container listens on
  11. List CRDs
  12. List instances of a CRD (storage states)
    1. To me, this is a real cool part. k9s wasn’t coded to know anything about these custom resource definitions – but the Kubernetes API is extensible and self-describing, so it was able to learn about it and would display any custom columns, as well.
  13. View YAML for a storage state
  14. Edit a storage state
  15. List and edit a config map
  16. List, view, and decode a secret

k9s is a powerful tool that makes it easy to quickly get done what you need to get done in Kubernetes!

About the Author

David Norton profile.

David Norton

Director, Platform Engineering

Passionate about continuous delivery, cloud-native architecture, DevOps, and test-driven development.Passionate about continuous delivery, cloud-native architecture, DevOps, and test-driven development.

  • Experienced in cloud infrastructure technologies such as Terraform, Kubernetes, Docker, AWS, and GCP.
  • Background heavy in enterprise JVM technologies such as Groovy, Spring, Spock, Gradle, JPA, Jenkins.
  • Focus on platform transformation, continuous delivery, building agile teams and high-scale applications.

One thought on “Explore your Kubernetes cluster with k9s

  1. Samson says:

    Thank you for taking your time and sharing the article, it is very helpful.

Leave a Reply

Your email address will not be published. Required fields are marked *

Related Blog Posts
Google Professional Machine Learning Engineer Exam 2021
Exam Description A Professional Machine Learning Engineer designs, builds, and productionizes ML models to solve business challenges using Google Cloud technologies and knowledge of proven ML models and techniques. The ML Engineer is proficient in all aspects […]
Designing Kubernetes Controllers
There has been some excellent online discussion lately around Kubernetes controllers, highlighted by an excellent Speakerdeck presentation assembled by Tim Hockin. What I’d like to do in this post is explore some of the implications […]
React Server Components
The React Team recently announced new work they are doing on React Server Components, a new way of rendering React components. The goal is to create smaller bundle sizes, speed up render time, and prevent […]
Jolt custom java transform
Jolt is a JSON to JSON transformation library where the transform is defined in JSON. It’s really good at reorganizing the json data and massaging it into the output JSON you need. Sometimes, you just […]