Concurrent kubectl
data:image/s3,"s3://crabby-images/7a4eb/7a4eb7dde90b3c6effc80e7c87d5259e805747df" alt=""
A cli to simplify working with kubectl for some common workflows
Installation
Find the latest binaries here
Usage
ckube
lets you think in terms of services instead of pods (mostly).
$ ckube
A CLI to simplify working with kubectl.
Usage:
ckube [command]
Available Commands:
exec execute a command in a container
help Help about any command
logs get logs from a service
ls list pods in kubernetes
top View cpu and memory usage for pods
Flags:
--context string the kubernetes context (defaults to value currently used by kubectl)
-h, --help help for ckube
-n, --namespace string the kubernetes namespace (defaults to value currently used by kubectl)
Use "ckube [command] --help" for more information about a command.
Kubernetes services are often an abstraction over multiple pods, particularly if the replicas are scaled. If a k8s cluster has a service called nginx
you could have several pods which might be named something like this:
nginx-3528986049-kpd4z
nginx-3528986049-71s10
nginx-3528986049-f6mwf
nginx-3528986049-ltx6j
nginx-3528986049-m3cmm
nginx-3528986049-h8cnn
nginx-3528986049-6v4c1
Getting logs for the nginx service is easy with ckube
# single uspecified nginx pod:
ckube logs nginx
# all nginx pods
ckube logs nginx
# follow the logs
ckube logs nginx -f
data:image/s3,"s3://crabby-images/44e48/44e485154a3e8d1ce567925ca39e656edd148353" alt=""
Similar concurrent functionality exists for exec
data:image/s3,"s3://crabby-images/513cd/513cd51a3284d574b3228dddf64ee3a865b74a88" alt=""
data:image/s3,"s3://crabby-images/65bd0/65bd0f3d33cb0ce1b1db012b79d01adc26ea5c7c" alt=""
Read the blog post about ckube
here
Contributing
PR's accepted
If you are looking to build the project:
go get -d github.com/devonmoss/ckube
cd $GOPATH/src/github.com/devonmoss/ckube