🚚 improve database connection stability with healthcheck

This commit is contained in:
Markus Benjamin Tabler 2026-06-27 22:48:32 +02:00
parent 8779e11065
commit ce9d8e8815

View file

@ -4,6 +4,10 @@ services:
image: mariadb:10.11 image: mariadb:10.11
container_name: ${CONTAINER_NAME}-db container_name: ${CONTAINER_NAME}-db
restart: ${RESTART_POLICY} restart: ${RESTART_POLICY}
healthcheck:
test: ["CMD", "mysqladmin", "ping", "-h", "localhost"]
timeout: 5s
retries: 10
environment: environment:
- MYSQL_ROOT_PASSWORD=${DB_MYSQL_ROOT_PASSWORD} - MYSQL_ROOT_PASSWORD=${DB_MYSQL_ROOT_PASSWORD}
- MYSQL_DATABASE=${DB_DATABASE} - MYSQL_DATABASE=${DB_DATABASE}
@ -28,7 +32,8 @@ services:
container_name: ${CONTAINER_NAME} container_name: ${CONTAINER_NAME}
restart: ${RESTART_POLICY} restart: ${RESTART_POLICY}
depends_on: depends_on:
- passbolt-db - passbolt-db:
condition: service_healthy
environment: environment:
- APP_FULL_BASE_URL=https://${SUBDOMAIN}.${DOMAIN} - APP_FULL_BASE_URL=https://${SUBDOMAIN}.${DOMAIN}
- DB_HOST=passbolt-db - DB_HOST=passbolt-db
@ -67,7 +72,7 @@ services:
- "traefik.http.routers.${ROUTER_NAME}.tls.certresolver=${CERTIFICATE_RESOLVER}" - "traefik.http.routers.${ROUTER_NAME}.tls.certresolver=${CERTIFICATE_RESOLVER}"
- "traefik.http.services.${ROUTER_NAME}.loadbalancer.server.port=80" - "traefik.http.services.${ROUTER_NAME}.loadbalancer.server.port=80"
- "traefik.docker.network=${TRAEFIK_NETWORK}" - "traefik.docker.network=${TRAEFIK_NETWORK}"
- "traefik.http.routers.${ROUTER_NAME}.middlewares=passbolt-headers@docker" - "traefik.http.routers.${ROUTER_NAME}.middlewares=passbolt-headers@docker"
- "traefik.http.middlewares.passbolt-headers.headers.customrequestheaders.X-Forwarded-Proto=https" - "traefik.http.middlewares.passbolt-headers.headers.customrequestheaders.X-Forwarded-Proto=https"
@ -76,4 +81,5 @@ networks:
name: traefik name: traefik
external: true external: true
internal_net: internal_net:
driver: bridge driver: bridge
name: passbolt_internal_net