Skip to content

Probes Liveness, readiness & startup

Kubernetes propose une fonctionnalité appelée "probes", qui joue un rôle important pour garantir la santé des applications s'exécutant dans son environnement.

Ces sondes sont classées en trois catégories (liveness, readiness et startup). Elle permettent à Kubernetes de surveiller l'état des applications et de prendre les mesures appropriées pour maintenir leur fonctionnement optimal.

Dans cet article de blog, nous allons explorer l'importance de ces sondes pour améliorer les capacités d'autoréparation de Kubernetes et fournir une compréhension complète de leur fonctionnement. Nous examinerons chaque type de sonde, leurs objectifs spécifiques et la manière dont elles contribuent à la résilience globale des applications conteneurisées.

Health Check:

Health checks are a simple way to let the system know whether an instance of your app is working. If the instance of your app is not working, the other services should not access it or send requests to it. Instead, requests should be sent to another instance that is ready or you should retry sending requests.

The system should be able to bring your app to a healthy state. By default, Kubernetes will start sending traffic to the pod when all the containers inside the pod have started. Kubernetes will restart containers when they crash. This default behavior should be enough to get started. Making deployments more robust becomes relatively straightforward as Kubernetes helps create custom health checks.

Kubernetes probes:

Kubernetes probes are a mechanism for providing the Kubernetes control plane with information about the internal state of your applications. They let your cluster identify running pods that are in an unhealthy state.

Probes are kubelet’s answer to the health checks, there are three handlers:

  • ExecAction: Command execution check, if the command’s exit status is 0, it is considered a success.
  • TCPSocketAction: TCP check to determine if the port is open, if open, it is considered a success.
  • HTTPGetAction: HTTP check to determine if the status code is equal to or above 200 and below 400.

Each type of probe has common configurable fields:

  • initialDelaySeconds: Probes start running after initialDelaySeconds after container is started (default: 0)
  • periodSeconds: How often probe should run (default: 10)
  • timeoutSeconds: Probe timeout (default: 1)
  • successThreshold: Required number of successful probes to mark container healthy/ready (default: 1)
  • failureThreshold: When a probe fails, it will try failureThreshold times before deeming unhealthy/not ready (default: 3)

These parameters need to be configured per your application’s spec.

Kubernetes probe types:

Kubernetes has three basic probe types:

  • Liveness probes: they detect whether a pod is healthy by running a command or making a network request inside the container. Containers that fail the check are restarted.
  • Readiness probes: they identify when a container is able to handle external traffic received from a service. Containers don’t become part of their services until they pass a readiness probe.
  • Startup probes: they provide a way to defer the execution of liveness and readiness probes until a container indicates it’s able to handle them. Kubernetes won’t direct the other probe types to a container if it has a startup probe that hasn’t yet succeeded.

Sequence of health probes:

This diagram effectively illustrates the workflow of Kubernetes health probes and their impact on a container’s lifecycle.

The process begins with the deployment of the container in Kubernetes. After the container starts, the startup probe checks if the application within the container is ready to run. If the startup probe succeeds, it proceeds to the readiness probe. If the startup probe fails, Kubernetes restarts the container.

When the startup probe is successful, the readiness probe is executed. This probe determines if the container is ready to serve traffic. If the readiness probe is successful, Kubernetes initiates the liveness probe to continually monitor the container’s health. If the readiness probe fails, traffic to the container is stopped. Kubernetes will retry the readiness probe until it succeeds or the failure threshold is exceeded. If the failure threshold is exceeded, Kubernetes restarts the container.

Once the startup probe and the readiness probes are successful, Kubernetes continuously checks the health of the container during its runtime. If the liveness probe is successful, it will continue to monitor at defined intervals. If the liveness probe fails, Kubernetes will restart the container. After restarting the container, the process begins again with the startup probe.

Startup probes:

Startup probes should be used when the application in your container could take a significant amount of time to reach its normal operating state. Applications that would crash or throw an error if they handled a liveness or readiness probe during startup need to be protected by a startup probe.

This ensures the container doesn’t enter a restart loop due to failing healthiness checks before it’s finished launching.

Creating a startup probe:

Startup probes are created by adding a startupProbe field within the spec.containers portion of a pod’s manifest.

Exec Probe:

Exec probe runs a command inside the container as a health check; the command’s exit code determines the success.startupProbe:
initialDelaySeconds: 1
periodSeconds: 5
timeoutSeconds: 1
successThreshold: 1
failureThreshold: 1
exec:
command:
- cat
- /etc/nginx/nginx.conf

TCP Probe:

TCP probe checks if the specified port is open or not; an open port points to success.startupProbe:
initialDelaySeconds: 1
periodSeconds: 5
timeoutSeconds: 1
successThreshold: 1
failureThreshold: 1
tcpSocket:
host:
port: 80

HTTP Probe:

HTTP probe sends an HTTP GET request with defined parameters.

HTTP Probe has additional options to configure.

  • host: Host/IP to connect to (default: pod IP)
  • scheme: Scheme to use when making the request (default: HTTP)
  • path: Path
  • httpHeaders: An array of headers defined as header/value tuples.
  • port: Port to connect to

Tip: Host header should be set in httpHeaders.

startupProbe:
initialDelaySeconds: 1
periodSeconds: 2
timeoutSeconds: 1
successThreshold: 1
failureThreshold: 1
httpGet:
host:
scheme: HTTP
path: /
httpHeaders:
- name: Host
value: myapplication1.com
port: 80
initialDelaySeconds: 5
periodSeconds: 5

Readiness probes:

Similar to other probes, it checks to ensure the container is ready to accept traffic. Unlike the liveness probe which checks to see if things remain ship-shape, the readiness probe makes sure things are in a state that traffic can start flowing.

This is at the pod level. Meaning all of the containers must be in a ready state prior to anything being passed to the service. The startup probe, while also similar, is at the application level. It would be active prior to any liveness or readiness probes.

Creating a Readiness probe:

Readiness probes are created by adding a readinessProbe field within the spec.containers portion of a pod’s manifest.

Exec Probe:

Exec action has only one field, and that is command. Exit status of the command is checked, and the status of zero (0) means it is healthy, and another value means it is unhealthy.readinessProbe:
initialDelaySeconds: 1
periodSeconds: 5
timeoutSeconds: 1
successThreshold: 1
failureThreshold: 1
exec:
command:
- cat
- /etc/nginx/nginx.conf

TCP Probe:

We need to define host and port parameters, host parameter defaults to the cluster-internal pod IP.readinessProbe:
initialDelaySeconds: 1
periodSeconds: 5
timeoutSeconds: 1
successThreshold: 1
failureThreshold: 1
tcpSocket:
host:
port: 80

HTTP Probe:

HTTP Probe has additional options to configure.

  • host: Host/IP to connect to (default: pod IP)
  • scheme: Scheme to use when making the request (default: HTTP)
  • path: Path
  • httpHeaders: An array of headers defined as header/value map
  • port: Port to connect to

Tip: If you need to set the Host header of the HTTP, please do so on httpHeaders, instead of the host parameter.

readinessProbe:
initialDelaySeconds: 1
periodSeconds: 2
timeoutSeconds: 1
successThreshold: 1
failureThreshold: 1
httpGet:
host:
scheme: HTTP
path: /
httpHeaders:
- name: Host
value: myapplication1.com
port: 80
initialDelaySeconds: 5
periodSeconds: 5

Liveness probes:

Liveness probes enhance Kubernetes’ ability to manage workloads on your behalf. Without probes, you need to manually monitor your pods to distinguish which application instances are healthy and which are not. This becomes time-consuming and error-prone when you’re working with hundreds or thousands of pods.

Allowing unhealthy pods to continue without detection degrades your service’s stability over time. Pods that are silently failing as they age, perhaps due to race conditions, deadlocks, or corrupted caches, will gradually reduce your service’s capacity to handle new requests. Eventually, your entire pod fleet could be affected, even though all the containers report as running.

Creating a Liveness probe:

Liveness probes are defined by a pod’s spec.containers.livenessProbe field.

There are three types of actions kubelet performs on a pod, which are:

  1. Executes a command inside the container
  2. Checks for a state of a particular port on the container
  3. Performs a GET request on container’s IP

Define a liveness command:livenessProbe:
exec:
command:
- sh
- /tmp/status_check.sh
initialDelaySeconds: 10
periodSeconds: 5

Define a liveness HTTP request:livenessProbe:
httpGet:
path: /health
port: 8080
initialDelaySeconds: 5
periodSeconds: 3

Define a TCP liveness probe:---
initialDelaySeconds: 15
livenessProbe: ~
periodSeconds: 20
port: 8080
tcpSocket: ~

Conclusion:

In conclusion, Kubernetes probes are essential for ensuring the health and resilience of your applications.

They provide a more streamlined, data-driven approach to monitoring, which facilitates informed decision-making and responsive adjustments to changes in your application’s usage patterns.

By using health checks, you can improve your application availability, reduce your maintenance burden, and make certain that your application is not only running but also accessible to your users.

LINK
https://itnext.io/understanding-kubernetes-probes-better-apps-health-checks-3a057341371a
https://medium.com/@omernaci/liveness-readiness-and-startup-probes-e05d6f1c96e0

Leave a Reply

Your email address will not be published. Required fields are marked *