Awesome
Kubectl with auto-completion in a docker container
The purpose of this tool is to have a fully portable kubectl
command line tool with a few convinience utilities.
Quick testing of a cluster with well-known/customized kubectl
setup.
What is included
to see all the packages installed in both tags, you can use
docker sbom
command
KUBECTL_COMP_VERSION=v1.0.0
docker sbom piotrzan/kubectl-comp:"$KUBECTL_COMP_VERSION"-bash
docker sbom piotrzan/kubectl-comp:"$KUBECTL_COMP_VERSION"-zsh
There are two images, one simple image with bash shell containing:
kubectl
- latestIt is easy to override
kubectl
version by using--build-arg
flag in docker build commanddocker build --build-arg KUBECTL_VERSION=v1.19.4 --rm -f "Dockerfile" -t piotrzan/kubectl-comp:v1.0.0-bash "."
- useful aliases
Use this image if you want to quickly check and explore Kubernetes cluster without investing too much time.
This image is optimized for size performance and is based on Apline
base image and is 16 MB compressed size.
And one is a fancy image for zsh with more tools preinstalled:
kubectl
- latestzsh-autosuggestions
- very useful zsh shell plugin showing previous commands and enabling easy autofill of texthelm
- Kubernetes package managerokteto
- development platform for Kubernetes applicationsk9s
- cluster monitoring toolkubectx
- easily switch between Kubernetes contextskubens
- easily switch between Kubernetes namespacestmux
based on highly customized, great repo from samoshkin- popular tools:
curl, wget, git
- useful aliases
Use this image if you want to monitor and develop for Kubernetes. This is my default image with all favourite tools and settings.
This image is optimized for usability and is based on Ubuntu
base image and is 168 MB compressed size.
How to use
After running docker container, all the clusters running on the localhost should be available for kubectl
command.
Aliases
Make use of aliases defined for both shells bash and zsh
Instead of typing kubectl all the time, abbreviate it to just “k”
alias k=kubectl
Check what is running on the cluster
alias kdump='kubectl get all --all-namespaces'
Display helpful info for creating k8s resources imperatively
alias krun='k run -h | grep “# “ -A2'
Quickly spin up busybox pod for diagnostic purposes
alias kdiag='kubectl run -it --rm debug --image=busybox --restart=Never -- sh'
Supported tags
-
zsh docker pull piotrzan/kubectl-comp:v1.0.0-zsh Dockerfile
-
bash docker pull piotrzan/kubectl-comp:v1.0.0-bash Dockerfile
How the images are build
Build image with bash shell
docker build --rm -f "Dockerfile" -t piotrzan/kubectl-comp:v1.0.0-bash "."
Build image with zsh shell
docker build --rm -f "Dockerfile" -t piotrzan/kubectl-comp:v1.0.0-zsh "."
Convinient scripts to run the contianer
Use run.ps1
or run.sh
for windows or linux respectivels.
Alternatively use docker-compose.yaml, this works by mounting a volume on the $HOME/.kube folder on the host.
Another option is running make
(defaults to content of run script). Make
can be run from root directory and will run images depending on the tasks. Linux has make
installed by default, for Windows please install first Make for Windows.
ZSH container will be ran by default.
Linux Example
By default make
command will run zsh
container with direct mount on the ($home)/.kube directory.
Run contianer with passthrough to local network
docker run -d --network=host --name=kubectl-host --rm -it piotrzan/kubectl-comp:v1.0.0-bash
Generate raw config from kubeclt on localhost and copy the config to the container
kubectl config view --raw > config
docker cp ./config kubectl-host:./root/.kube
Attach back to the contianer with kubeconfig file containing info about clusters running on localhost
docker attach kubectl-host
Extending the image
If you would like to add your own customization, you can easily do it and use docker commit
to create your own version of the image.
docker commit $(docker ps -aqf "name=kubectl-host") piotrzan/kubectl-comp:v1.0.0-zsh
- this captures contianer kubectl-host as a new tag
docker push piotrzan/kubectl-comp:v1.0.0-zsh