Below is a process to install the Kubernetes cluster on three nodes. with MicroK8s.
+ Deploying MicroK8s on node 1, node 2, and node 3
data:image/s3,"s3://crabby-images/20f34/20f346a20fc3c24339a037376ffa1f56ffa54da8" alt=""
Install MicroK8s directly from the snap store.
sudo apt install snapd
data:image/s3,"s3://crabby-images/e5fa6/e5fa65470e2d0eee703463c009c720f20b20c3ee" alt=""
To follow a specific upstream release series it’s possible to select a channel during installation, for example, v1.18 series.
sudo snap install microk8s --classic --channel=1.18/stable
data:image/s3,"s3://crabby-images/afefa/afefac2437824cf3c69473234f3b5f4c39851988" alt=""
Configure your firewall to allow pod-to-pod and pod-to-internet communication.
sudo ufw allow in on cni0 && sudo ufw allow out on cni0
sudo ufw default allow routed
data:image/s3,"s3://crabby-images/6ffa8/6ffa8108ea96526d8fde9d79110cf98e03e356d2" alt=""
Dashboard, core-dns, or local storage can be enabled by running the microk8s enable
command:
microk8s enable dns dashboard storage
sudo usermod -a -G microk8s tung
sudo chown -f -R tung ~/.kube
newgrp microk8s
data:image/s3,"s3://crabby-images/01cf8/01cf852cb19c9678b817d6713cce01cb14671ae8" alt=""
data:image/s3,"s3://crabby-images/81a2b/81a2bc36dc2570985ea8ae90010ca0e2cbbecc9c" alt=""
Get the output of the first node.
data:image/s3,"s3://crabby-images/091b7/091b74b32faae5b505f2b73e73c24c92f55d56f0" alt=""
Get token.
data:image/s3,"s3://crabby-images/fea96/fea964674c293de1aad4fbb9c9fa66ea552dedcf" alt=""
Copy and paste the token on the following screenshot.
data:image/s3,"s3://crabby-images/942c0/942c01a6666fd458cea1fae816b608a24ae61f2d" alt=""
Kubernetes dashboard.
data:image/s3,"s3://crabby-images/35021/35021141bf52c209241175e0c27d8f75869f19a3" alt=""
Get status of mircok8s service.
data:image/s3,"s3://crabby-images/fe0e9/fe0e9d1790817104a60adf8b323b15a62b1ef454" alt=""
Do previous steps on node 2 and node 3. We do not need to install dashboard service on node 2 and node 3.
data:image/s3,"s3://crabby-images/b0179/b01790fa469104328706602aad584f933524c561" alt=""
data:image/s3,"s3://crabby-images/40899/408997098400ef10e23d415ea302070e596d255c" alt=""
+ Create a MicroK8s multi-node cluster.
Now let’s focus on creating the Kubernetes cluster. On the first node run a command below.
microk8s add-node
This command will give you the following output:
data:image/s3,"s3://crabby-images/b64e0/b64e013b831f99f4edd589a1cdeb7ee44cd4525c" alt=""
On node 2, join the cluster.
data:image/s3,"s3://crabby-images/6e070/6e0708963dfae9bfe69d4b3cfa52a11be354eb12" alt=""
Repeat this process (including generating a token, run it from the joining node) for the third node.
data:image/s3,"s3://crabby-images/6862b/6862bcf47146d000f43e5395e0efd1a8a8c54291" alt=""
data:image/s3,"s3://crabby-images/81c85/81c851560066206043c5d31544efca593392bdd2" alt=""
+ Deploy a sample containerized application
Let’s now create a microbot deployment with three pods via the kubectl cli. Run this on any of the control plane nodes:
microk8s kubectl create deployment microbot --image=dontrebootme/microbot:v1
microk8s kubectl scale deployment microbot --replicas=3
To expose our deployment we need to create a service:
microk8s kubectl expose deployment microbot --type=NodePort --port=80 --name=microbot-service
After a few minutes, check your cluster.
data:image/s3,"s3://crabby-images/3e3ba/3e3ba5f04976fe67be3ae6c15966a474d28b9557" alt=""
Check IP address of the K8S node.
data:image/s3,"s3://crabby-images/a6947/a69476463cf21749c4a69b75b480b1baf05b3657" alt=""
Access micro-bot service via the port 30711.
data:image/s3,"s3://crabby-images/5b25c/5b25ccf2c1e5b0dce9b561fca9374d226e5a041a" alt=""
Kubernetes dashboard.
data:image/s3,"s3://crabby-images/46f6f/46f6f483212e72f9965eae6ec8733a776a9cfbd7" alt=""