services: app: build: . container_name: lista-zakupow-app #ports: # - "${APP_PORT:-8000}:8000" expose: - "${APP_PORT:-8000}" healthcheck: test: ["CMD", "python", "-c", "import urllib.request; import sys; req = urllib.request.Request('http://localhost:${APP_PORT:-8000}/healthcheck', headers={'X-Internal-Check': '${HEALTHCHECK_TOKEN}'}); sys.exit(0) if urllib.request.urlopen(req).read() == b'OK' else sys.exit(1)"] interval: 30s timeout: 10s retries: 3 start_period: 10s env_file: - .env volumes: - .:/app - ./uploads:/app/uploads - ./instance:/app/instance restart: unless-stopped varnish: image: varnish:latest container_name: lista-zakupow-varnish depends_on: app: condition: service_healthy ports: - "${APP_PORT:-8000}:80" volumes: - ./deploy/varnish/default.vcl:/etc/varnish/default.vcl:ro environment: - VARNISH_SIZE=256m healthcheck: test: [ "CMD-SHELL", "curl -fsS -H 'X-Internal-Check=${HEALTHCHECK_TOKEN}' http://localhost/healthcheck | grep -q OK" ] interval: 30s timeout: 5s retries: 3 env_file: - .env networks: - lista-zakupow_network restart: unless-stopped pgsql: image: postgres:latest container_name: lista-zakupow-pgsql-db environment: POSTGRES_DB: ${DB_NAME} POSTGRES_USER: ${DB_USER} POSTGRES_PASSWORD: ${DB_PASSWORD} volumes: - ./db/pgsql:/var/lib/postgresql/data restart: unless-stopped networks: - lista-zakupow_network profiles: ["pgsql"] mysql: image: mysql:8 container_name: lista-zakupow-mysql-db environment: MYSQL_DATABASE: ${DB_NAME} MYSQL_USER: ${DB_USER} MYSQL_PASSWORD: ${DB_PASSWORD} MYSQL_ROOT_PASSWORD: 89o38kUX5T4C volumes: - ./db/mysql:/var/lib/mysql restart: unless-stopped networks: - lista-zakupow_network profiles: ["mysql"] networks: lista-zakupow_network: driver: bridge name: lista-zakupow_default