minikube start --driver=docker
minikube status
data:image/s3,"s3://crabby-images/d418a/d418ad03aa0fad2622a25629b8fc3c6199c9488e" alt=""
- To connect, know the IP and SSH
minikube ip
ssh docker@<ip>
- user=docker
- password=tcuser
minikube ssh
Once connected:
docker ps
From k8s_:
- k8s_kube-proxy_kube-proxy-bvjpp_kube-system
- k8s_kube-apiserver_kube-apiserver-minikube_kube-system
- k8s_kube-controller-manager_kube-controller-manager-minikube_kube-system
- k8s_kube-scheduler_kube-scheduler-minikube_kube-system
- k8s_coredns_coredns-565d847f94-gptzm_kube-system
- k8s_storage-provisioner_storage-provisioner_kube-system
- k8s_etcd_etcd-minikube_kube-system
From k8s_POD:
- k8s_POD_kube-proxy-bvjpp_kube-system
- k8s_POD_mypod_default
- k8s_POD_storage-provisioner_kube-system
- k8s_POD_coredns
- k8s_POD_etcd-minikube_kube-system
- k8s_POD_kube-scheduler-minikube_kube-system
- k8s_POD_kube-apiserver-minikube_kube-system
- k8s_POD_kube-controller-manager-minikube_kube-system
- No kubectl inside the node:
data:image/s3,"s3://crabby-images/809b8/809b8ff2c2f48381aeff6a9a22248701c2e5e137" alt=""
- exit and:
kubectl cluster-info
data:image/s3,"s3://crabby-images/171a1/171a1b8a5e4c96b9c338fee428c25a8bdf811bb7" alt=""
- list nodes in the cluster
kubectl get nodes
data:image/s3,"s3://crabby-images/3a8c1/3a8c1931b92f34bc5a04e68638c41007f337cd20" alt=""
- List pods available in this cluster (default looks at default namespace only!)
kubectl get nodes
kubectl get namespaces
data:image/s3,"s3://crabby-images/f250f/f250f61cc94e4afbfa51d80692becd65e6468799" alt=""
- Check pods from kube-system namespace (master node):
kubectl get pods --namespace=kube-system
data:image/s3,"s3://crabby-images/00dfa/00dfab34651c34465ff40e174590b484f0a9b395" alt=""
- Create nginx pod
kubectl run <podname> --image=nginx
data:image/s3,"s3://crabby-images/741c8/741c85e5396f59ec696a834f3eed2f465fef9d73" alt=""
- Check container is running
data:image/s3,"s3://crabby-images/cd122/cd122c82daf4c874aa80e133a271ae465dcb5991" alt=""
- Get details about the pod
kubectl describe pod <podname>
data:image/s3,"s3://crabby-images/6064c/6064c8b9756b7c68d6b9d15c215f41a6215b50db" alt=""
data:image/s3,"s3://crabby-images/44e95/44e956ff5509ed279e533d9cf4053f1752f02f27" alt=""
- Connect to node again
kubectl ssh
docker ps | grep nginx
data:image/s3,"s3://crabby-images/7ea87/7ea870f9aabc349d8f6d198ec77f7164c0ea7a8a" alt=""
It create a paused container k8s_POD for the specific pod (to lock and keep namespace of specific pod)
- Connect to the container running nginx
docker exec -it <containerID> sh
hostname
hostname -i
data:image/s3,"s3://crabby-images/2b1cb/2b1cb42606acae65e82636644d82cb35decc4587" alt=""
data:image/s3,"s3://crabby-images/051d9/051d908d720747245a743d46b47a986b7c7373b8" alt=""
- Check nginx is up and running
curl 172.17.0.4
data:image/s3,"s3://crabby-images/040a7/040a74681d59c736c4789f7be7fa3d046b5ac411" alt=""
- Exit both the container and the K8s node
- Check the pod IP address (same as container IP) – If several containers in pod -> they share the same IP address
kubectl get pods -o wide
data:image/s3,"s3://crabby-images/f3b6b/f3b6be00106a99e57dc8363f54c7b61679e8e2c8" alt=""
- Delete the pod
kubectl delete pod <podname>
data:image/s3,"s3://crabby-images/df6c4/df6c40cb316eb2c6f6b747f01b67e4a358ae3f87" alt=""
- you can use alias to shortcut command
alias k="kubectl"