https://github.com/applejag/kubectl-klock
A kubectl plugin to render watch output in a more readable fashion
https://github.com/applejag/kubectl-klock
go go-cli golang golang-cli hacktoberfest krew-plugin kubectl-plugin
Last synced: 4 months ago
JSON representation
A kubectl plugin to render watch output in a more readable fashion
- Host: GitHub
- URL: https://github.com/applejag/kubectl-klock
- Owner: applejag
- License: gpl-3.0
- Created: 2022-09-01T18:29:17.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-09-16T07:44:35.000Z (5 months ago)
- Last Synced: 2024-10-11T10:14:45.598Z (4 months ago)
- Topics: go, go-cli, golang, golang-cli, hacktoberfest, krew-plugin, kubectl-plugin
- Language: Go
- Homepage:
- Size: 978 KB
- Stars: 44
- Watchers: 2
- Forks: 2
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-repositories - applejag/kubectl-klock - A kubectl plugin to render watch output in a more readable fashion (Go)
README
# kubectl-klock
data:image/s3,"s3://crabby-images/28091/28091f318cd64ee82793255f0bfb907ef65d1b4b" alt="demonstration animation"
[data:image/s3,"s3://crabby-images/c90c1/c90c1c9675f662f9b9a03f36c44028f597bb7069" alt="Latest Release"](https://github.com/applejag/kubectl-klock/releases)
[data:image/s3,"s3://crabby-images/70c0c/70c0c723244214880b96b9a4d9add9af5650e861" alt="REUSE status"](https://api.reuse.software/info/github.com/applejag/kubectl-klock)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.## Installation
### Krew
[data:image/s3,"s3://crabby-images/e533d/e533dc89bcaab8befe78886b653c49d2f4c054e8" alt="krew status"](https://krew.sigs.k8s.io/plugins/)
```sh
kubectl krew install klock
```### Snap
[data:image/s3,"s3://crabby-images/74765/74765096b1f9dba87d58bbe227470b93e8d59f19" alt="klock"](https://snapcraft.io/klock)
```sh
sudo snap install klock
```### Scoop
data:image/s3,"s3://crabby-images/7f1c9/7f1c963198008201d199ba7d1e9c1bcc30062715" alt="Scoop"
```pwsh
scoop bucket add applejag https://github.com/applejag/applejag-bucket
scoop install applejag/kubectl-klock
```### Nix
[data:image/s3,"s3://crabby-images/acf69/acf694666144d169c34ef8bf18d2637ba7d57a00" alt="Packaging status"](https://repology.org/project/kubectl-klock/versions)
```sh
nix-shell -p kubectl-klock
```### Pre-built binaries
You can download pre-built binaries from the latest GitHub release:
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:```sh
tar -xzf kubectl-klock_linux_amd64.tar.gz
sudo mv ./kubectl-klock /usr/local/bin
```### From source
Requires Go 1.21 (or later).
```sh
go install github.com/applejag/kubectl-klock@latest
```## Usage
Supports a wide range of flags
```sh
kubectl klock [name(s)] [flags]
```### Examples
```sh
# 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:
```text
→/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/hide deleted
G/end go to end ↓/ctrl+n show next suggestion f toggle fullscreen
↑/ctrl+p show previous suggestion
tab accept a suggestion
```## Features
- Pagination, for when the terminal window gets too small (height-wise)
- Same output format as `kubectl get`
- Watch arbitrary resources, just like `kubectl get [name]`
- Filter results
- Auto updating age column.
- Colors on statuses (e.g `Running`) and fractions (e.g `1/1`) to make
them stand out more.- Restart watch when kubeconfig file changes (flag: `--watch-kubeconfig`, `-W`),
such as when changed by [kubectx](https://github.com/ahmetb/kubectx).## Completion
To get completion when writing `kubectl klock`, you need to add
[`./bin/kubectl_complete-klock`](./bin/kubectl_complete-klock)
to your `PATH`.For example:
```sh
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
```