Table of contents
So, I’ve read a bunch of beginner guides on Kubernetes, and honestly? Most of them either lack depth or are just step-by-step walkthroughs that can leave you stuck. But a few were truly great, and they inspired me to create the best Kubernetes guide ever one that’ll have you running your cluster and creating objects with ease, no matter your background. I hope I succeed on this journey.
What is Kubernetes?
Yep, I know, this is how every other blog starts. But hey, it’s always good to know more about our beloved Kubernetes, right?
Kubernetes ("K8s" if you’re in a hurry) is an open-source system that automates container deployment tasks. Originally developed by Google, it’s now maintained by the awesome folks at the Cloud Native Computing Foundation (CNCF).
Fun Fact: The Kubernetes logo represents a ship’s wheel, symbolizing that you’re the captain of your cluster, steering those containers with the help of an orchestrator.
Kubernetes Features: Why It's the Best Thing Since Sliced Bread
Just like I said, Kubernetes has a fantastic community contributing to its continuous improvement. Here are some of the cool features that make Kubernetes the go-to platform for container management.
Automated Rollouts, Scaling, and Rollbacks: Imagine having a personal assistant who always ensures you have the right number of containers running, even when one goes down. That’s Kubernetes for you!
Service Discovery, Load Balancing, and Network Ingress: Worried about network issues? Kubernetes has you covered. It’s like having a GPS for your containers.
Stateless and Stateful Applications: Whether your app needs to remember everything or nothing at all, Kubernetes has built-in objects to manage both.
Storage Management: Persistent storage? No problem. Kubernetes abstracts it all for you, no matter where it’s stored.
Declarative State: Kubernetes lets you describe the desired state of your cluster, and it automatically makes it so, like magic 🪄 but better.
Works Across Environments: Whether you’re in the cloud, on the edge, or just tinkering on your laptop, Kubernetes is there for you.
Highly Extensible: Think of Kubernetes as a LEGO set, you can build anything you want with custom object types, controllers, and operators. (My favorite is Knative🤫)
Getting Started: Let’s Roll To Our Ship 🚢 ☸️
Kubernetes can run in various environments, thanks to the range of distributions it offers. Creating a cluster using the official distribution can be complex, so most people start with a packaged solution like Minikube (my personal favorite ❤️), MicroK8s, K3s, or Kind.
When I first started learning Kubernetes, I used Docker Desktop’s Kubernetes extension, it was the easy way out 🤫. But, if you want to dive deep, installing Kubernetes via Minikube is a great practice. You can also try Kubeadm cause it often asked in CKA if you're preparing for it.
Pro Tip: If you’re lazy like me, Homebrew is your best friend.
brew install minikube
after the Minikube does its thing 🍺 type your welcoming command.
minikube start
And just like that, you’ve got a working Kubernetes cluster! if you got stuck you can also refer to their docs here.
The welcome screen would be similar to this.
Yay! My fellow captains, we just started our ship(Kubernetes cluster).
Basic Kubernetes Terms: Let's Get Familiar With Tools
Now that we’ve got Kubernetes running, let’s talk about some basic terms. What if you don't know them? If you’re eager to learn more about its architecture, I’ve got a great article for you, check it out to deepen your understanding. I hope you've read the article, but even if not, I assume you have enough knowledge to follow this walkthrough.
Nodes
Nodes are the physical machines that make up your Kubernetes cluster. They run the containers you create. Let’s see our node in action
kubectl get nodes
You’ll see something like this✨
For more details, we can use
Kubectl get node -o wide
in kubectl
the get
is a command which is used to retrieve and display information about Kubernetes resources. When you use kubectl get
, you are asking Kubernetes to fetch and show you details about specific resources.
Namespace
In Kubernetes, we have a helpful concept called namespace. Think of it as a folder for your Kubernetes objects, providing a layer of isolation to keep everything organized and prevent mixing things up like a salad. 🌱
Namespaces are especially useful in environments with many users or teams, allowing each to have their own isolated resources without interfering with others.
You might already know this, but if not, here’s a quick tip: there are already existing namespaces in your cluster. You can list them with the following command:
kubectl get ns
Here, ns
is just a shorthand for namespace
—a little shortcut to save you some typing! and now we can see all the existing namespaces.
Bunch of namespaces we can see, Let’s create our own namespace for this guide
kubectl create ns mycookbook
The create
command in kubectl
is used to create various objects within your Kubernetes cluster.
Cooking with Kubernetes:
Now, all our work will be neatly tucked away in our namespace called mycookbook. Neat, right?
Pods: The Building Blocks
Pods are the smallest and most basic objects in Kubernetes. Instead of running containers directly on nodes, Kubernetes runs them inside pods. Think of a pod as a tortilla wrapping around your containers, sounds delicious, doesn’t it?
Let’s create our first tortilla I mean pod haha 😂
kubectl -n mycookbook run mypod --image=nginx --port=8080
so we are making our first pod with nginx which listens at port:8080, We can also see it while it's getting created if we are fast enough.
Kubectl -n my cookbook get pods
what about we see its whole journal? we can use the describe
command which is very helpful on days when you are debubbing. So lets type
kubectl -n mycookbook describe pods/mypod
Let's verify our setup by hopping into our browser and visiting the given port. But wait, why do we see nothing when we visit our desired port? 🤔
Don’t worry, this is expected! By default, a Pod in Kubernetes is only accessible within the Kubernetes cluster itself. This means that external access is not available out of the box.
So, does this mean we can never access our first Pod?
Absolutely not! You can still access your Pod externally, but you’ll need to use a Kubernetes Service to expose it to the outside world. Kubernetes Services acts as an entry point, allowing external traffic to reach your Pods. So, while you may not
Making Pizza Kubernetes: Pods, Deployments, and Services
Oh God, I'm hungry now, I'm craving something like pizza 🍕, how about we make a pizza on Kubernetes instead of in our kitchen?😋
I’m making pizza out of niginx and my recipe will have 5 ngnix pod, and they listen to the port 8080 and this time we will eat it together 🤗
so lets make our dough(deployment) for our pizzas
Deployments: Dough ?
The Deployment is your recipe. It tells Kubernetes what kind of pizza (Pods) you want, how many you want to bake, and what ingredients (containers) to use. For example, you might want 5 Margherita pizzas (Pods) with the same ingredients (containers). Kubernetes will ensure that you have exactly 5 of these pizzas ready, all made from the same recipe. So let’s deploy 5 Nginx pods and call it pizza (for being simple).🍕
kubectl -n mycookbook create deployment pizza --image=nginx --replicas=3 --dry-run=client -o yaml > pizza.yml
yes we are making pizza from scratch and we should use yaml instead for those direct commands, Now when we cat pizza.yml
we could see a our pizza dough like this..
Oops, we only got 3 replicas, but we wanted 5! No worries, we can scale it up ⬆️. But before that, we should apply it by using apply
command.
kubectl apply -f pizza.yml
so we could see our deployment is being created, we can verify it by the kubectl -n mycookbook get deploy
and see it rolling 😊. But we got the dough for only 3 pizzas what should we do? compromise? Nah, we can we can scale it up ⬆️ by this.
kubectl -n mycookbook scale deploy/pizza --replicas=5
Clarification: The scale
command allows you to adjust the number of replicas (instances) of a deployment. In this case, it increases the number of Nginx pods from 3 to 5.
Or, you can use the edit
command to update the number of replicas directly.
What? What is an edit? can we also be creative like we get while making pizza? And the answer is Yes! 🙌
The edit
command in Kubernetes is indeed a powerful tool! It allows you to manually modify the configuration of your objects, like deployments. Here’s how it works:
Power and Caution: Just like wielding a sharp knife in the kitchen,
edit
gives you great control but requires careful handling. If not used properly, changes might cause unexpected issues with your deployment.How It Works: When you run the
edit
command, it opens the configuration of your deployment in your default text editor (like Vim or Nano). From there, you can make changes directly, such as updating the number of replicas in thereplicas
field.Safe Editing: Although powerful, it’s wise to proceed with caution. If you make a mistake, it could affect how your deployment behaves. A safer approach is to use the
edit
command to open the configuration, then save and apply changes carefully.
We’ll dive into using the edit
command later, and I promise you’ll get the hang of it! 🤗
Services: Plating and Serving 🍽️
Our pods(pizzas) are running, but how do we access them? That’s where Kubernetes Services comes in. They expose your pods to the network, letting you access them from outside the cluster.
One of the best resources for learning more about Kubernetes is its comprehensive documentation. Contributed to by experts from around the world, it simplifies complex concepts and enhances your understanding. So let's plate our pizzas ;) With the help of Kubernetes documentation(Kubernetes presentation book) by clicking here.
By reading through docs we can do this by adding this yaml to our pizza.
---
apiVersion: v1
kind: Service
metadata:
name: pizza
namespace: mycookbook
labels:
app: pizza
spec:
selector:
app: pizza
type: NodePort
ports:
- port: 80
targetPort: 80
protocol: TCP
nodePort: 30080 # Optional: Specify a NodePort or let Kubernetes assign one
You can copy this and there is also an easy way to do this but we are head chef right now so let's do everything from scratch 🤗, let's apply this, I have saved this file as pizzasvc.yml
, you can name it anything or you can also add it to our previous deployment file and apply
it.
Let's also verify it by kubectl -n mycookbook get svc/pizza
.We can see that it's ready to be served 😋.
But wait did we edit
command as I promised? no, right ? So let's use it cause I forgot to name our delicious pizzas as Margherita. So let us use it
kubectl -n mycookbook edit deploy/pizza
woah what just opened? the heart of our pizza❤️. let us find the place where we can name our pod Margherita.
kubectl -n mycookbook get deployment pizza -o jsonpath='{.spec.template.spec.containers[*].name}'
and now we have each container named a Margherita, Yummy 😋.
Reaching the endpoint: Time to eat 🤤
Now, we can check out your nginx pizza by visiting the assigned port. We can follow the pattern as http://<Node-IP>:<NodePort> . For me the NodePort is 30080 as I have defined you can check it by the kubectl -n mycookbook get svc
and for the node, we can use kubectl get node -o wide
.
we can use curl
but for Minikube it is useful to use minikube -n mycookbook svc pizza
There was another easy way to skip the service yaml part by using the kubectl -n mycookbook expose deploy/pizza --type=NodePort --port=80"
which can do the same But I wanted you guys to feel like a chef to learn it with heart ❤️.
So there you have it, folks! 🍕
If you followed along, you could have your very own pizza or whatever you were making cooked up and ready to serve. We all have a little chef inside us, and instead of a kitchen, we're using Kubernetes to cook our creations! 😉
But after cooking, what comes next? Dishes, right?
In the Kubernetes world, "doing the dishes" means cleaning up our resources to keep things tidy and efficient. Let’s go ahead and do that!
Cleaning Up: Doing the Dishes
To clean up everything we created:
Delete the Deployment:
kubectl -n mycookbook delete deployment pizza
Delete the Service:
kubectl -n mycookbook delete service pizza
Wrapping up: Farwell 😔
Yes, I know there are more advanced topics like RBAC, Ingress, Volumes, and many more. But those are for another time, as they dive deeper into the wonderful world of Kubernetes.
For now, I hope you've gotten a good overview of Kubernetes. I truly hope you learned something valuable today and enjoyed our little cooking adventure in the world of K8s.
As a parting gift, I want to share something cool with you. Did you know that Kubernetes has a beautiful dashboard? It’s like a control panel where you can visualize everything that’s happening in your cluster.
Wanna check it out? Just type
minikube dashboard
Isn’t that pretty? 😉 Enjoy exploring, and see you next time when we dive into the more advanced topics! ☸️