Kubernetes Headless Service

krzwiatrzyk - Oct 2 '21 - - Dev Community

What is a headless service?

Kubernetes Headless Service

A headless service is a Kubernetes Service without ClusterIP.

What is the difference between headless service and normal service?

First, let's see the differences between headless and headful service.

Kubernetes Headless Service

NOTE: Originally, there isn't something like "headful" service in Kubernetes nomenclature. It is used in this article to differentiate services.

After creating both services, it is visible that ClusterIP was not set for headless service.

Kubernetes Headless Service

I have 3 containers (called test-*) that will be included in headless and headful services.

Kubernetes Headless Service

First, let's check (with usage of dnsutils pod) what addresses will be returned from DNS for particular services.

Kubernetes Headless Service

Can you see the difference? If ClusterIP is set, then only one IP address is returned in answer, thus load balancing is done by the cluster itself. However, if ClusterIP is empty, addresses of all available endpoints are returned, allowing the application to know and decide which target instance to connect to.

Another approach with StatefulSets

With StatefulSets you can achieve the same behavior as with headless service by specifying spec.serviceName field (headful or headless, doesn't matter).

I have created a StatefulSet with 3 pods (test-*).

Kubernetes Headless Service

And pointed a headful service in the spec.

Kubernetes Headless Service

Now, it is possible to resolve specific pods in this service (this is not normally possible).

Kubernetes Headless Service

That's great, you can create an application that can connect to particular instances by name of the pod.

Drawback? Somehow, your client must know how many instances of the target application are there.

Headless service with StatefulSet

If StatefulSet has specified spec.serviceName field and targeted a headless service, then DNS discovery can be used for getting the number of instances available (i.e. 3) and then using the above solution to connect (i.e.: test-0.headful, test-1.headful, test-3.headful).

Where this is useful? One of the best examples is Kafka, where sometimes a particular topic's partition leader is on a different broker than the application connected to. Check the diagram below.

Kubernetes Headless Service

. . . .
Terabox Video Player