A kubectl
plugin to render the kubectl get pods --watch
output in a
much more readable fashion.
Think of it as running watch kubectl get pods
, but instead of polling,
it uses the regular watch feature to stream updates as soon as they occur.
kubectl krew install klock
sudo snap install klock
scoop bucket add applejag https://github.com/applejag/applejag-bucket
scoop install applejag/kubectl-klock
nix-shell -p kubectl-klock
You can download pre-built binaries from the latest GitHub release: https://github.com/applejag/kubectl-klock/releases/latest
Download the one that fits your OS and architecture, extract the
tarball/zip file, and move the kubectl-klock
binary to somewhere in your PATH.
For example:
tar -xzf kubectl-klock_linux_amd64.tar.gz
sudo mv ./kubectl-klock /usr/local/bin
Requires Go 1.21 (or later).
go install github.com/applejag/kubectl-klock@latest
Supports a wide range of flags
kubectl klock <resource> [name(s)] [flags]
# Watch all pods
kubectl klock pods
# Watch all pods with more information (such as node name)
kubectl klock pods -o wide
# Watch a specific pod
kubectl klock pods my-pod-7d68885db5-6dfst
# Watch a subset of pods, filtering on labels
kubectl klock pods --selector app=my-app
kubectl klock pods -l app=my-app
# Watch all pods in all namespaces
kubectl klock pods --all-namespaces
kubectl klock pods -A
# Watch other resource types
kubectl klock cronjobs
kubectl klock deployments
kubectl klock statefulsets
kubectl klock nodes
# Watch all pods, but restart the watch when your ~/.kube/config file changes,
# such as when using "kubectl config use-context NAME"
kubectl klock pods --watch-kubeconfig
kubectl klock pods -W
There's also some hotkeys available:
→/l/pgdn next page / filter by text ctrl+c quit
←/h/pgup prev page enter close the filter input field ?/esc close help
g/home go to start esc clear the applied filter d show all deleted
G/end go to end ↓/ctrl+n show next suggestion f toggle fullscreen
↑/ctrl+p show previous suggestion
tab accept a suggestion
-
Pagination, for when the terminal window gets too small (height-wise)
-
Same output format as
kubectl get
-
Watch arbitrary resources, just like
kubectl get <resource> [name]
-
Filter results
-
Auto updating age column.
-
Colors on statuses (e.g
Running
) and fractions (e.g1/1
) to make them stand out more. -
Restart watch when kubeconfig file changes (flag:
--watch-kubeconfig
,-W
), such as when changed by kubectx. -
Color themes powered by kubecolor
-
Shows deleted table rows for a short duration, controllable via the
--hide-deleted=10s
flag andKLOCK_HIDE_DELETED=10s
environment variable. Can be disabled to always show deleted rows by setting--hide-deleted=false
Command-line flags can be controlled via environment variables:
export KLOCK_ALL_NAMESPACES="true" # --all-namespaces
export KLOCK_FIELD_SELECTOR="status.phase!=Succeeded" # --field-separator
export KLOCK_HIDE_DELETED="false" # --hide-deleted
export KLOCK_LABEL_COLUMNS="app.kubernetes.io/name" # --label-columns
export KLOCK_OUTPUT="wide" # --output
export KLOCK_SELECTOR="team!=frontend" # --selector
export KLOCK_WATCH_KUBECONFIG="true" # --watch-kubeconfig
The command-line flags have precedense over the environment variables.
So if you set KLOCK_ALL_NAMESPACES=true
then you can revert the value
by passing the flag --all-namespaces=false
Klock uses kubecolor's coloring logic and behavior when coloring its output. See: https://kubecolor.github.io/customizing/themes/
Color settings that klock uses:
KUBECOLOR_THEME_BASE_DANGER
for rows with errorsKUBECOLOR_THEME_BASE_MUTED
for "No resources found"KUBECOLOR_THEME_BASE_MUTED
for deleted rowsKUBECOLOR_THEME_BASE_MUTED
for status lineKUBECOLOR_THEME_BASE_SECONDARY
for "FILTER:" promptKUBECOLOR_THEME_BASE_WARNING
for "No resources visible" when filteringKUBECOLOR_THEME_DATA_DURATIONFRESH
forAGE: 12h
when below thresholdKUBECOLOR_THEME_DATA_RATIO_EQUAL
forREADY: 1/1
KUBECOLOR_THEME_DATA_RATIO_UNEQUAL
forREADY: 0/1
KUBECOLOR_THEME_STATUS_ERROR
forSTATUS: CrashLoopBackOff
KUBECOLOR_THEME_STATUS_SUCCESS
forSTATUS: Running
KUBECOLOR_THEME_STATUS_WARNING
forSTATUS: Terminating
KUBECOLOR_THEME_TABLE_COLUMNS
for table columnsKUBECOLOR_THEME_TABLE_HEADER
for table header
You can configure these colors either via
environment variables
or via the ~/.kube/color.yaml
config file
To get completion when writing kubectl klock
, you need to add
./bin/kubectl_complete-klock
to your PATH
.
For example:
sudo curl https://github.com/applejag/kubectl-klock/raw/main/bin/kubectl_complete-klock -o /usr/local/bin/kubectl_complete-klock
sudo chmod +x /usr/local/bin/kubectl_complete-klock