====== Healthcheck con Docker ======
Contenido perteneciente al curso [[informatica:sistemas_operativos:cursos:docker_avanzado|Docker avanzado]]
Comprobación de "salud" del contenedor: revisar si el servicio está funcionando de forma adecuada.
Docker permite lanzar una comprobación, pero esta comprobación depende de nosotros. No es lo mismo comprobar que responda al puerto 80, que hacer comprobaciones más complejas.
Podemos hacer healthchecks en 3 partes:
* Al construir la imagen
* Al lanzar un contenedor (docker run)
* En Compose
* Usando otros contenedores
===== Healthcheck en imágenes =====
En un Dockerfile:
RUN echo "#!/bin/bash\n\nservice nginx status || exit 1" > /opt/healthcheck.sh
# con curl:
# RUN echo "#!/bin/bash\n\n curl -f http://localhost/ || exit 1" > /opt/healthcheck.sh
RUN chmod +x /opt/healthcheck.sh
FROM nginx
HEALTHCHECK --interval=30s --timeout=30s --start-period=5s --retries=3 CMD ["/opt/healthcheck.sh"]
# HEALTHCHECK --interval=10s --timeout=10s --start-period=5s --retries=3 CMD curl -f http://localhost:80 || exit 1
* ''interval'': cada cuanto tiempo se ejecuta la comprobación.
* ''timeout'': tiempo máximo para que la comprobación finalice exitosamente.
* ''start-period'': tiempo de espera desde que se lanza el contenedor hasta que ejecutamos la primera comprobación.
* ''retries'': número de veces consecutivas que puede fallar la comprobación antes de considerar que el contenedor está en estado //unhealthy//
* ''CMD'' es lo que ejecutaremos como test / comprobación del estado de salud del contenedor.
Otra opción:
HEALTHCHECK --interval=30s --timeout=5s --start-period=10s --retries=3 \
CMD [ $(curl -I -s http://127.0.0.1:8000 | head -n 1 | cut -d' ' -f2 | head -n 1) -eq 200 ] || exit 1
Al ver el estado del contenedor:
docker ps
===== Docker Compose =====
services:
web:
image: nginx
healthcheck:
interval: 5s
timeout: 5s
start_period: 10s
retries: 3
test: curl -f http://localhost || exit 1
===== A través de otro contenedor específico =====
Hay contenedores que permiten monitorizar el estado de contenedores y reiniciar aquellos //unhealthy//. Por ejemplo: [[https://hub.docker.com/r/willfarrell/autoheal|Docker Autoheal]]
docker run -d \
--name autoheal \
--restart=always \
-e AUTOHEAL_CONTAINER_LABEL=all \
-v /var/run/docker.sock:/var/run/docker.sock \
willfarrell/autoheal
Podemos incluirlo en un Compose:
services:
web:
image: nginx
# marcamos que queremos que actúe el Auto heal
labels:
- autoheal=true
healthcheck:
interval: 5s
timeout: 5s
start_period: 10s
retries: 3
test: curl -f http://localhost || exit 1
autoheal:
image: willfarrell/autoheal
restart: always
environment:
- AUTOHEAL_CONTAINER_LABEL=all
volumes:
- /var/run/docker.sock:/var/run/docker.sock