kubectx is a tool to switch between contexts (clusters) on kubectl faster.
kubens is a tool to switch between Kubernetes namespaces (and configure them for kubectl) easily.
# switch to another cluster that's in kubeconfigkubectxrancher-desktop# switch back to previous clusterkubectx-# change the active namespace on kubectlkubenskube-system# go back to the previous namespacekubens-
k9s
Kubernetes CLI To Manage Your Clusters In Style!
k9s
Kubectl commands
commonly used Kubectl commands
you can pratice kubectl commands at katacoda playground
kubectl version
kubectl cluster-info
kubectl get storageclass
kubectl get nodes
kubectl get ep kube-dns --namespace=kube-system
kubectl get persistentvolume
kubectl get PersistentVolumeClaim --namespace default
kubectl get pods --namespace kube-system
kubectl get ep
kubectl get sa
kubectl get serviceaccount
kubectl get clusterroles
kubectl get roles
kubectl get ClusterRoleBinding
# Show Merged kubeconfig settings.
kubectl config view
kubectl config get-contexts
# Display the current-context
kubectl config current-context
kubectl config use-context docker-desktop
kubectl port-forward service/ok 8080:8080 8081:80 -n the-project
# Delete evicted pods
kubectl get po --all-namespaces | awk '{if ($4 ~ /Evicted/) system ("kubectl -n " $1 " delete pods " $2)}'
Namespaces and Context
Execute the kubectl Command for Creating Namespaces
# Namespace for Developerskubectlcreate-fnamespace-dev.json# Namespace for Testerskubectlcreate-fnamespace-qa.json# Namespace for Productionkubectlcreate-fnamespace-prod.json
Assign a Context to Each Namespace
# Assign dev context to development namespace
kubectl config set-context dev --namespace=dev --cluster=minikube --user=minikube
# Assign qa context to QA namespace
kubectl config set-context qa --namespace=qa --cluster=minikube --user=minikube
# Assign prod context to production namespace
kubectl config set-context prod --namespace=prod --cluster=minikube --user=minikube
Switch to the Appropriate Context
# List contexts
kubectl config get-contexts
# Switch to Dev context
kubectl config use-context dev
# Switch to QA context
kubectl config use-context qa
# Switch to Prod context
kubectl config use-context prod
kubectl config current-context
kubectl proxy creates proxy server between your machine and Kubernetes API server. By default it is only accessible locally (from the machine that started it).
# get all the logs for a given pod:kubectllogsmy-pod-name# keep monitoring the logskubectl-flogsmy-pod-name# Or if you have multiple containers in the same pod, you can do:kubectl-flogsmy-pod-nameinternal-container-name# This allows users to view the diff between a locally declared object configuration and the current state of a live object.kubectlalphadiff-fmything.yml
Execute commands in running Pods
kubectlexec-itmy-pod-name--/bin/sh
CI/CD
Redeploy newly build image to existing k8s deployment
# To get all the deploys of a deployment, you can do:kubectlrollouthistorydeployment/DEPLOYMENT-NAME# Once you know which deploy you’d like to roll back to, you can run the following command (given you’d like to roll back to the 100th deploy):kubectlrolloutundodeployment/DEPLOYMENT_NAME--to-revision=100# If you’d like to roll back the last deploy, you can simply do:kubectlrolloutundodeployment/DEPLOYMENT_NAME
Tips and Tricks
# Show resource utilization per node:kubectltopnode# Show resource utilization per pod:kubectltoppod# if you want to have a terminal show the output of these commands every 2 seconds without having to run the command over and over you can use the watch command such aswatchkubectltopnode# --v=8 for debuging kubectlgetpo--v=8
troubleshoot headless services
kgetep# ssh to one of the container and run dns check:host<httpd-discovery>
Alias
alias k="kubectl"alias watch="watch "alias kg="kubectl get"alias kgdep="kubectl get deployment"alias ksys="kubectl --namespace=kube-system"alias kd="kubectl describe"alias bb="kubectl run busybox --image=busybox:1.30.1 --rm -it --restart=Never --command --"
you can use busybox for debuging inside cluster
bbnslookupdemobbwget-qO-http://demo:8888bbsh
after SSH to a container, you can use this command to check connectivity to external host
# install netcat only if missingaptupdate&&apt-yinstallnetcat# example connectivity testsnc-vzhost.docker.internal80nc-zvsome_egress_hostname1433
Container Security
for better security add following securityContext settings to manifest
securityContext:# Blocking Root ContainersrunAsNonRoot:true# Setting a Read-Only FilesystemreadOnlyRootFilesystem:true# Disabling Privilege EscalationallowPrivilegeEscalation:false# For maximum security, you should drop all capabilities, and only add specific capabilities if they’re needed:capabilities:drop: ["all"]add: ["NET_BIND_SERVICE"]
Debug k8s
For many steps here you will want to see what a Pod running in the k8s cluster sees. The simplest way to do this is to run an interactive busybox Pod:
Ephemeral containers are useful for interactive troubleshooting when kubectl exec is insufficient because a container has crashed or a container image doesn't include debugging utilities, such as with distroless images.
This allows a user to inspect a running pod without restarting it and without having to enter the container itself to, for example, check the filesystem, execute additional debugging utilities, or initial network requests from the pod network namespace. Part of the motivation for this enhancement is to also eliminate most uses of SSH for node debugging and maintenance
# First, create a pod for the example: kubectlrunephemeral-demo--image=k8s.gcr.io/pause:3.1--restart=Never# add a debugging container kubectlalphadebug-itephemeral-demo--image=busybox--target=ephemeral-demo
Generateing k8s YAML from local files using --dry-run
# generate a kubernetes tls secret from fileskubectlcreatesecrettlskeycloak-secrets-tls \--key key.pem--certcert.pem \-o yaml--dry-run=client>keycloak-secrets-tls.yml
verify
# verify by getting from k8kubectlgetsecretkeycloak-secrets-tls-ojsonpath="{.data.tls.crt}"|base64--decode# verify from file yq'.data."tls.crt"'keycloak-secrets-tls.yml|base64--decode
iTerm2 tips
in iTerm2
split screen horizontally
go to the bottom screen and split it vertically
I was using top screen for the work with yaml files and kubectl.
Left bottom screen was running:
watch kubectl get pods
Right bottom screen was running:
watch "kubectl get events --sort-by='{.lastTimestamp}' | tail -6"
With such setup it was easy to observe in real time how my pods are being created.