feat: healthchecks for postgres, redis, minio;

feat: backend container now depends on postgres, redis and minio (must be healthy);
feat: frontend depends on backend being healthy
This commit is contained in:
2025-06-17 22:20:49 +03:00
parent 577292e31f
commit 9e8dd9bf2f

View File

@@ -3,9 +3,16 @@ services:
backend: backend:
build: ./backend build: ./backend
restart: unless-stopped restart: unless-stopped
depends_on:
postgres:
condition: service_healthy
redis:
condition: service_healthy
minio:
condition: service_healthy
healthcheck: healthcheck:
test: ["CMD", "/usr/bin/curl", "-f", "http://localhost:8080/service/health"] test: ["CMD", "/usr/bin/curl", "-f", "http://localhost:8080/service/health"]
interval: 30s interval: 5s
timeout: 10s timeout: 10s
retries: 3 retries: 3
ports: ports:
@@ -16,11 +23,19 @@ services:
frontend: frontend:
build: ./frontend build: ./frontend
restart: unless-stopped restart: unless-stopped
depends_on:
backend:
condition: service_healthy
networks: networks:
- easywish-network - easywish-network
minio: minio:
image: minio/minio image: minio/minio
healthcheck:
test: [ "CMD", "curl", "-I", "localhost:9000/minio/health/live" ]
interval: 5s
timeout: 10s
retries: 3
environment: environment:
MINIO_ROOT_USER: ${MINIO_ROOT_USER} MINIO_ROOT_USER: ${MINIO_ROOT_USER}
MINIO_ROOT_PASSWORD: ${MINIO_ROOT_PASSWORD} MINIO_ROOT_PASSWORD: ${MINIO_ROOT_PASSWORD}
@@ -34,6 +49,11 @@ services:
postgres: postgres:
image: postgres:latest image: postgres:latest
healthcheck:
test: [ "CMD", "pg_isready", "-q", "-d", "${POSTGRES_DB}", "-U", "${POSTGRES_USER}" ]
interval: 5s
timeout: 10s
retries: 3
environment: environment:
POSTGRES_USER: ${POSTGRES_USER} POSTGRES_USER: ${POSTGRES_USER}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD} POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
@@ -48,6 +68,11 @@ services:
redis: redis:
image: eqalpha/keydb image: eqalpha/keydb
healthcheck:
test: [ "CMD", "redis-cli", "--raw", "incr", "ping" ]
interval: 5s
timeout: 10s
retries: 3
command: ["keydb-server", "--requirepass", "${REDIS_PASSWORD}"] command: ["keydb-server", "--requirepass", "${REDIS_PASSWORD}"]
environment: environment:
REDIS_PASSWORD: ${REDIS_PASSWORD} REDIS_PASSWORD: ${REDIS_PASSWORD}