services: app: build: . container_name: zbiorka-app #ports: # - "${APP_PORT:-8080}:${APP_PORT}" expose: - "${APP_PORT}" healthcheck: test: [ "CMD", "python", "-c", "import urllib.request; import sys; req = urllib.request.Request('http://localhost:${APP_PORT}/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: - ./instance:/app/instance networks: - zbiorki_app_network restart: unless-stopped varnish: #build: ./deploy/varnish image: varnish:latest container_name: zbiorka-varnish depends_on: app: condition: service_healthy ports: - "${APP_PORT:-8080}:80" volumes: - ./deploy/varnish/default.vcl:/etc/varnish/default.vcl:ro environment: - VARNISH_SIZE=256m env_file: - .env networks: - zbiorki_app_network restart: unless-stopped mysql: image: mysql:8 container_name: zbiorka-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: - zbiorki_app_network profiles: ["mysql"] pgsql: image: postgres:18 container_name: zbiorka-pgsql-db environment: POSTGRES_DB: ${DB_NAME} POSTGRES_USER: ${DB_USER} POSTGRES_PASSWORD: ${DB_PASSWORD} PGDATA: /var/lib/postgresql/ volumes: - ./db/pgsql:/var/lib/postgresql networks: - zbiorki_app_network restart: unless-stopped profiles: ["pgsql"] networks: zbiorki_app_network: driver: bridge