Author: Vaishnavi Shivde
Kubernetes, the leading container orchestration platform, has transformed the way we deploy, manage, and scale applications. One of the core components that makes Kubernetes so powerful is its robust service management system. In this blog post, we will explore what services are in Kubernetes, why they are essential, and how to work with them effectively.
Service in Kubernetes:
In Kubernetes (k8s), a “Service” is an abstraction that defines a logical set of Pods and a policy by which to access them, sometimes called a microservice. Kubernetes Services enable Pods to communicate with each other and with other parts of the system, ensuring reliable network connectivity and load balancing.
Use Cases:
- Microservices Communication: Services enable different microservices within a cluster to communicate with each other reliably.
- External API Exposure: Exposing an internal API to external users via a LoadBalancer service.
- Internal Load Balancing: Distributing requests among backend Pods for a scalable web application.
Types of Services 🧩
- ClusterIP (Default) 🌐
- Description: Exposes the Service on an internal IP in the cluster, accessible only within the cluster.
- Use Case: Internal communication between services within the same cluster.
- Example:
apiVersion: v1
kind: Service
metadata:
name: my-service
spec:
selector:
app: MyApp
ports:
- protocol: TCP
port: 80
targetPort: 9376
type: ClusterIP
2. NodePort 🔓
- Description: Exposes the Service on each Node’s IP at a static port (the NodePort). Accessible externally using
<NodeIP>:<NodePort>
. - Use Case: Direct access to a service from outside the cluster without a load balancer.
- Example:
apiVersion: v1
kind: Service
metadata:
name: my-service
spec:
selector:
app: MyApp
ports:
- protocol: TCP
port: 80
targetPort: 9376
nodePort: 30007
type: NodePort
3. LoadBalancer ⚖️
- Description: Exposes the Service externally using a cloud provider’s load balancer.
- Use Case: Automatically provision a load balancer for your service in a cloud environment.
- Example:
apiVersion: v1
kind: Service
metadata:
name: my-service
spec:
selector:
app: MyApp
ports:
- protocol: TCP
port: 80
targetPort: 9376
type: LoadBalancer
4. ExternalName 🌏
- Description: Maps a Service to the contents of the
externalName
field (e.g., a CNAME record), without proxying any traffic. - Use Case: Redirects requests to an external service (e.g., an external database or third-party service).
- Example:
apiVersion: v1
kind: Service
metadata:
name: my-service
spec:
type: ExternalName
externalName: my.external.service.com
Task 01 : Creating a Service for your ToDo app Deployment
- Create a Service
service.yml
for your todo-app Deployment
apiVersion: v1
kind: Service
metadata:
name: todo-service
namespace: todo
spec:
selector:
app: todo
ports:
- protocol: TCP
port: 80
targetPort: 8000
- Apply the Service definition to your K8s cluster using command.
kubectl apply -f service.yml -n <namespace-name>
- Verify that the Service is working by accessing the todo-app using the Service’s IP and Port in your Namespace.
kubectl get services -n <namespace-name>
- You should see something like this:
This shows that you have one Service named todo-service
that exposes port 80 of your Pods as port 8000 on an internal IP address 10.98.16.138
in the todo
Namespace.
Task 02 : Creating a ClusterIP Service for internal cluster access
A ClusterIP Service is the default type of Service that exposes our Pods within the cluster using an internal IP address. This type of Service is only accessible from within the cluster.
- Create a YAML file named
cluster_ip_service.yml
with the following content:
apiVersion: v1
kind: Service
metadata:
name: todo-cluster-ip-service
namespace: todo
spec:
type: ClusterIP
selector:
app: todo
ports:
- protocol: TCP
port: 80
targetPort: 8000
This file defines a Service object named todo-cluster-ip-service
that exposes port 80 of our Pods as port 8000 on an internal IP address. The Service belongs to the todo
Namespace and select the Pods that have the label app: todo
. The type: ClusterIP
specifies that this is a ClusterIP Service.
2. Apply the ClusterIP Service definition to your K8s cluster.
kubectl apply -f cluster_ip_service.yml -n todo
3. Verify that the Service is created by running:
kubectl get services -n todo
You should see something like this:
This shows that you have one ClusterIP Service named todo-cluster-ip-service
that exposes port 80 of your Pods as port 8000 on an internal IP address 10.109.228.211
in the todo
Namespace.
Task 03: Creating a LoadBalancer Service for external access
A LoadBalancer Service is a type of Service that exposes our Pods using an external load balancer provided by our cloud provider or platform. This type of Service is accessible from outside the cluster.
- Create a YAML file named
load-balancer-service.yml
with the following content:
apiVersion: v1
kind: Service
metadata:
name: todo-load-balancer-service
namespace: todo
spec:
type: LoadBalancer
selector:
app: todo
ports:
- protocol: TCP
port: 80
targetPort: 8000
This file defines a Service object named todo-load-balancer-service
that exposes port 80 of our Pods as port 8000 on an external IP address. The Service belongs to the todo
Namespace and select the Pods that have the label app: todo
. The type: LoadBalancer
specifies that this is a LoadBalancer Service.
2. Apply the YAML file to create the Service by running:
kubectl apply -f load-balancer-service.yml -n todo
3. Verify that the Service is created by running:
kubectl get services -n todo
You should see something like this:
This shows that you have one LoadBalancer Service named todo-load-balancer-service
that exposes port 80 of your Pods as port 80 on an external IP address 10.110.153.22
in the todo
Namespace.
Conclusion
In this blog post, we learned how to work with Services in Kubernetes, a key concept that allows us to expose and access our applications in a cluster. We also deployed and managed different types of Services for our sample ToDo app that we created on Day 32.
I hope you enjoyed this blog post and learned something new. If you have any questions or feedback, please feel free to leave a comment below.
Thank you for reading and stay tuned for more!
Author: Vaishnavi Shivde