Logo

dev-resources.site

for different kinds of informations.

Understand Kubernetes Without the Headaches

Published at
10/2/2024
Categories
kubernetes
webdev
developer
coding
Author
Idil Saglam
Understand Kubernetes Without the Headaches

Kubernetes (K8s) is a tool for managing containers. It is useful when you have many containers and want to manage them smartly and automatically.

Why do we need Kubernetes?

Let's say you've built a shopping website. When you first launch it, you might have a small number of users, so your app is only running on one server, and it works fine.

Now, let's say it's Black Friday, and thousands of people are visiting your site simultaneously to shop. One server won't be able to handle that much traffic. Your website might slow down or even crash because the server is overloaded.

If you use Kubernetes, you can add more servers and run multiple copies of your app on those servers. This will spread the traffic across all the servers so that no single server gets too much traffic. So, even when lots of people are using your website, it will keep things running smoothly. 

When traffic returns to normal, Kubernetes can reduce the number of servers to save resources and costs.

So, you'd need Kubernetes to ensure that your app can handle sudden spikes in traffic and keep running without problems, especially during sales events, product launches, or whenever you expect more users than usual.

Plus: When you need to update your app, Kubernetes does it gradually (rolling updates), so your app keeps running without downtime.

Fancy Kubernetes that you need to understand 

Cluster: 

Clusters are a group of machines (can be physical or virtual) that work together.These machines can be located in the cloud, in your data center, or on your computer.

A cluster is made up of:

  • Master node: The brain of Kubernetes, which manages everything.
  • Worker nodes: The machines where your app containers run.

Pods

A Pod is the smallest part of Kubernetes. It's where your app's containers run. If you want to run your app, Kubernetes places it inside a Pod. If you need more than one copy of your app running (for example, to handle more users), Kubernetes creates multiple Pods, each running a copy of your app.

Example: If you want to run 5 copies of your app, Kubernetes will create 5 Pods, each one running your app inside a container.

Deployment

A Deployment is a way to tell Kubernetes how many copies of your app you want running. For example, if you say, "I need 3 copies of my app running at all times," Kubernetes will make sure 3 Pods are running.

If one Pod crashes or stops working, Kubernetes will automatically create a new one to keep 3 Pods running at all times.

Service

A Service in Kubernetes helps you expose your app to the outside world (like the internet) or connect different parts of your app internally. It gives your app a fixed address, so even if the Pods running your app are restarted or moved to another machine, your app is still accessible at the same address.

Scaling

When more people start using your app and the traffic increases, you might need more copies of your app to handle the load. Kubernetes can automatically scale your app by starting more Pods. Likewise, if traffic decreases, Kubernetes can stop some of the Pods to save resources.

A simple workflow with Kubernetes

  1. You write your app and package it in a Docker container.
  2. You create a Kubernetes deployment to tell Kubernetes how many copies (Pods) of your app to run.
  3. Kubernetes takes care of the rest: It starts the specified number of Pods, monitors them, and automatically restarts them if any of them fail.
  4. Scaling: If more users need your app, Kubernetes can increase the number of Pods to handle the extra traffic.
  5. Updates: When you update your app, Kubernetes replaces the old Pods with new ones, gradually updating your app without causing downtime.

In summary, Kubernetes simplifies the management of containerized applications by automating tasks like deployment, scaling, and updating. While it may seem complex at first, understanding the key concepts like clusters, Pods, deployments, and services can make it an incredibly powerful tool for keeping your apps running smoothly and efficiently.

Happy coding!

Featured ones: