Create a Kubernetes cluster in your Windows computer in a few minutes!
Installing Multipass
First of all, let’s install Multipass. Access the official website (https://multipass.run/), select Windows OS and click in “Download Multipass for Windows”.
data:image/s3,"s3://crabby-images/4fa20/4fa20b136cb3d69f5ab2a12214010fd0ffca5824" alt=""
Now, run the installer.
In the Welcome window, click in Next.
data:image/s3,"s3://crabby-images/22190/22190eed319275de6af1b41aead5fe2c44c75c51" alt=""
In the License Agreement, click in “I Agree”.
data:image/s3,"s3://crabby-images/fd823/fd823749d3868ece66c1273b581a01057061d558" alt=""
In Hypervisor window, left Microsoft Hyper-V checked and click in Next.
data:image/s3,"s3://crabby-images/95fcf/95fcf0d99b5f3a5e23fd3c62c4314625751969f1" alt=""
In the “Add multipass to PATH” window, click in Next.
data:image/s3,"s3://crabby-images/7779f/7779f5b0cd9fd68a1dc52845e294bcdaa4e2de18" alt=""
In “Choose Install Location” window, click in Next.
data:image/s3,"s3://crabby-images/92b71/92b7182728b9226220b71a0489c0824f34f1cf6e" alt=""
In “Choose Components” window, click in Install.
data:image/s3,"s3://crabby-images/dbee5/dbee522d40e968da48538f6e87777b97a91c84be" alt=""
When the setup is completed, click in Finish.
data:image/s3,"s3://crabby-images/a7e86/a7e866f920720e80895b7da083a264ab740dda73" alt=""
Creating a Virtual Machine
Now, let’s create our first Virtual Machine, open the PowerShell and run the following command:
multipass launch -n k8s -c 2 -m 2G -d 20G
This command will create an Ubuntu virtual machine named “k8s” with 2 CPU cores (-c), 2GB of memory (-m) and 20GB of disk (-d).
data:image/s3,"s3://crabby-images/b791a/b791a99b6543a1111535a2f9e8f8f4d31d19e97d" alt=""
data:image/s3,"s3://crabby-images/a099f/a099fb6a67d335d586c86b1f3a57fbc58a630cff" alt=""
data:image/s3,"s3://crabby-images/db658/db658ac882593b3b0268d488566ff03f712296a5" alt=""
data:image/s3,"s3://crabby-images/0978e/0978e9cbba2b8d71310d1b4ee08e6bc3bed2ca86" alt=""
To check the configuration of the virtual machine that we created, run the command:
multipass info k8s
data:image/s3,"s3://crabby-images/805ef/805ef23557fd3f525bb53bf21c54be50862c5339" alt=""
To list all virtual machines created, run the command:
multipass list
data:image/s3,"s3://crabby-images/aa2e6/aa2e60f522566f9698e3e2f6dcd2c7d889eed249" alt=""
Installing MicroK8s
Now that we have our virtual machine ready, let’s install the MicroK8s on it!
To do that, run the following command:
multipass exec k8s -- sudo snap install microk8s --classic --channel=1.18/stable
data:image/s3,"s3://crabby-images/f2ba8/f2ba87cb3dd188982a481923d2239049a9b01993" alt=""
data:image/s3,"s3://crabby-images/42f92/42f9223f32e717af08f091b853e74e3d90a3c846" alt=""
data:image/s3,"s3://crabby-images/cd4d3/cd4d391a63af683681418aa1de5075077302e1a9" alt=""
data:image/s3,"s3://crabby-images/58f3a/58f3a806479070618e60452463738cc517506b63" alt=""
Now we have to add the user ubuntu to microk8s group, to do that, run the following command:
multipass exec k8s -- sudo usermod -a -G microk8s ubuntu
data:image/s3,"s3://crabby-images/95690/95690e873777dd10b9f65a6a056f0d3343d6a9cb" alt=""
And then, change the user for the .kube folder.
multipass exec k8s -- sudo chown -f -R ubuntu ~/.kube
data:image/s3,"s3://crabby-images/eb846/eb8465adf6c80d48ca270bcbc1596bde21c45941" alt=""
If you need to access the virtual machine shell, run this command:
multipass shell k8s
data:image/s3,"s3://crabby-images/7f45b/7f45bcd6715bcd7265a07bd8a58cdfa30f7b9f62" alt=""
When can interact with the kubernetes cluster using the kubectl command installed in the k8s virtual machine, you just need to run this command:
multipass exec k8s -- /snap/bin/microk8s.kubectl get nodes
data:image/s3,"s3://crabby-images/22fd9/22fd975af75ed5da2453a998a52f382fb37ba662" alt=""
Now is time to create our first pod. Let’s deploy a NGinx image in our cluster. To do that run this command:
multipass exec k8s -- /snap/bin/microk8s.kubectl create deployment nginx --image=nginx
data:image/s3,"s3://crabby-images/9c54d/9c54d4b4a6414f04e850cefab6ec655469df561b" alt=""
Let’s check our pods…
multipass exec k8s -- /snap/bin/microk8s.kubectl get pods
data:image/s3,"s3://crabby-images/6ec3d/6ec3d2d11d8cc7f1f40fe5f4a9be754e1737b9dd" alt=""
Now let’s get the kubernetes config file. Doing that we can run kubectl commands from our machine directly.
multipass exec k8s -- /snap/bin/microk8s.kubectl config view --raw
data:image/s3,"s3://crabby-images/537a4/537a40c0283464976c1a4a0d40bf2cde28a1de66" alt=""
Copy this content and paste in the file c:\Users\<Your_User>\.kube\config .
PS: If you don’t have kubectl installed in your windows machine, follow this steps to get it done: https://kubernetes.io/docs/tasks/tools/install-kubectl-windows/
As you can see, the server address is pointing to 127.0.0.1, so we need to change that to our ubuntu virtual machine IP address.
data:image/s3,"s3://crabby-images/7b0f3/7b0f3507bd52c02d50f6a43e5ab0d042903071b8" alt=""
To get the virtual machine IP address, run this command:
multipass info k8s
Or…
multipass list
data:image/s3,"s3://crabby-images/50e0d/50e0d4a745958ab4be1bf2ab5a83d8021b5129eb" alt=""
Replace the localhost (127.0.0.1) IP address with your ubuntu IP address in the c:\Users\<Your_User>\.kube\config file.
Now we can run kubectl commands directly from our PowerShell..
data:image/s3,"s3://crabby-images/62496/62496919ffca62caf93c9931a6829343165ea312" alt=""
To access the NGinx web page, we need to create a port forward from our computer to the pod.
kubectl port-forward pod/nginx-f89759699-kbnpb 80:80
data:image/s3,"s3://crabby-images/402c7/402c7582df916f6b440c6321b05acc5dd12d2760" alt=""
Now open http://localhost in your browser.
data:image/s3,"s3://crabby-images/25506/25506e4bae5a71295bcdeaa95d193eba69cc1e47" alt=""
Success!!!!!
Adding nodes to our cluster
To add another node to our cluster, first we need to create a new virtual machine like we did before:
multipass launch -n k8s2 -c 2 -m 2G -d 20G
multipass exec k8s2 -- sudo snap install microk8s --classic --channel=1.18/stable
multipass exec k8s2 -- sudo usermod -a -G microk8s ubuntu
multipass exec k8s2 -- sudo chown -f -R ubuntu ~/.kube
data:image/s3,"s3://crabby-images/c1d10/c1d1030bd2b52382210f8cd74111417ca17a6247" alt=""
Now let’s get the command to add a node to the cluster:
multipass exec k8s -- /snap/bin/microk8s add-node
data:image/s3,"s3://crabby-images/32f13/32f1391257e283410820a8cc3ce52dc479c93a73" alt=""
Now we have to run this command in the k8s2 virtual machine:
multipass exec k8s2 -- /snap/bin/microk8s join 172.19.222.222:25000/EvaHJiotpFdEljCvOqBgjNziEVbHTyTt
data:image/s3,"s3://crabby-images/58595/585952d760c160d7a10f8f86cf265f1022875529" alt=""
PS: Don’t forget to replace the IP address and the code to your own!
Let’s check our cluster now…
kubectl get nodes
data:image/s3,"s3://crabby-images/17c56/17c56bd48ebcc68141bdbff429ffd880b01ba1f7" alt=""
To remove a node from cluster, run this command:
multipass exec k8s — /snap/bin/microk8s remove-node k8s2
data:image/s3,"s3://crabby-images/44350/443508ce737adcceade98f8b035d8b2e011613fe" alt=""
data:image/s3,"s3://crabby-images/15623/156237599bde64fd2594c30a3a583e0f0ad08b86" alt=""
Deleting a Virtual Machine in Multipass
Run the command “multipass list” to check all your virtual machines.
data:image/s3,"s3://crabby-images/ddcb2/ddcb26a6fc9bed84ae70822c4387887cb5c6cdae" alt=""
To delete a virtual machine, run the command:
multipass delete k8s2
data:image/s3,"s3://crabby-images/a4996/a49967255cf8c9e1381a15fd457b0be3516e92b9" alt=""
The virtual machine will be marked as deleted
data:image/s3,"s3://crabby-images/facee/facee241d8492bdf2f34022ba7361bca10bddf10" alt=""
But you can recover it running the command:
multipass recover k8s2
And then…
multipass start k8s2
data:image/s3,"s3://crabby-images/642d2/642d21287787e10268ead7fb8c10bb1ce7d62999" alt=""
To really delete the virtual machine from your computer, you have to run two commands:
multipass delete k8s2
multipass purge
data:image/s3,"s3://crabby-images/0a065/0a065d032f9222ce4efc45f45dd40030134570f6" alt=""
That’s all folks!!!