Files
zbiorki_app/docker-compose.yml
2025-10-07 21:17:32 +02:00

85 lines
2.1 KiB
YAML

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
- VARNISH_ADMIN_LISTEN_ADDRESS=127.0.0.1
- VARNISH_ADMIN_LISTEN_PORT=6082
healthcheck:
test:
[
"CMD-SHELL",
"varnishadm -S /etc/varnish/secret -T 127.0.0.1:6082 ping -t 1 >/dev/null",
]
interval: 30s
timeout: 5s
retries: 3
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