|
| 1 | +services: |
| 2 | + reverse-proxy: |
| 3 | + image: traefik:v3.4 |
| 4 | + command: |
| 5 | + - "--providers.docker=true" |
| 6 | + - "--providers.docker.exposedByDefault=false" |
| 7 | + - "--entrypoints.web.address=:80" |
| 8 | + - "--entrypoints.websecure.address=:443" |
| 9 | + - "--entrypoints.web.http.redirections.entryPoint.to=websecure" |
| 10 | + - "--entrypoints.web.http.redirections.entryPoint.scheme=https" |
| 11 | + - "--certificatesresolvers.letsencrypt.acme.httpchallenge=true" |
| 12 | + - "--certificatesresolvers.letsencrypt.acme.httpchallenge.entrypoint=web" |
| 13 | + - "--certificatesresolvers.letsencrypt.acme.email=admin@tum.de" |
| 14 | + - "--certificatesresolvers.letsencrypt.acme.storage=/letsencrypt/acme.json" |
| 15 | + restart: unless-stopped |
| 16 | + ports: |
| 17 | + - "80:80" |
| 18 | + - "443:443" |
| 19 | + volumes: |
| 20 | + - /var/run/docker.sock:/var/run/docker.sock |
| 21 | + - ./letsencrypt:/letsencrypt |
| 22 | + |
| 23 | + server: |
| 24 | + image: ghcr.io/aet-devops25/team-server-down/server:latest |
| 25 | + environment: |
| 26 | + DB_HOST: ${DB_HOST:-db} |
| 27 | + DB_PORT: ${DB_PORT:-5432} |
| 28 | + DB_NAME: ${DB_NAME:-postgres} |
| 29 | + DB_USER: ${DB_USER:-postgres} |
| 30 | + DB_PASSWORD: ${DB_PASSWORD:-postgres} |
| 31 | + depends_on: |
| 32 | + db: |
| 33 | + condition: service_healthy |
| 34 | + restart: unless-stopped |
| 35 | + networks: |
| 36 | + - server |
| 37 | + labels: |
| 38 | + - "traefik.enable=true" |
| 39 | + - "traefik.http.routers.server.rule=Host(`${SERVER_HOST}`)" |
| 40 | + - "traefik.http.services.server.loadbalancer.server.port=8080" |
| 41 | + - "traefik.http.routers.server.entrypoints=websecure" |
| 42 | + - "traefik.http.routers.server.tls.certresolver=letsencrypt" |
| 43 | + |
| 44 | + client: |
| 45 | + image: ghcr.io/aet-devops25/team-server-down/client:latest |
| 46 | + environment: |
| 47 | + - PUBLIC_API_URL=${PUBLIC_API_URL} |
| 48 | + depends_on: |
| 49 | + - server |
| 50 | + restart: unless-stopped |
| 51 | + labels: |
| 52 | + - "traefik.enable=true" |
| 53 | + - "traefik.http.routers.client.rule=Host(`${CLIENT_HOST}`)" |
| 54 | + - "traefik.http.services.client.loadbalancer.server.port=3000" |
| 55 | + - "traefik.http.routers.client.entrypoints=websecure" |
| 56 | + - "traefik.http.routers.client.tls.certresolver=letsencrypt" |
| 57 | + - "traefik.http.middlewares.client-compress.compress=true" |
| 58 | + - "traefik.http.routers.client.middlewares=client-compress" |
| 59 | + - "traefik.http.routers.client.priority=1" |
| 60 | + |
| 61 | + db: |
| 62 | + image: postgres:16.2-bullseye |
| 63 | + restart: unless-stopped |
| 64 | + environment: |
| 65 | + POSTGRES_USER: postgres |
| 66 | + POSTGRES_PASSWORD: postgres |
| 67 | + healthcheck: |
| 68 | + test: [ "CMD-SHELL", "sh -c 'pg_isready -U postgres -d postgres'" ] |
| 69 | + interval: 10s |
| 70 | + timeout: 3s |
| 71 | + retries: 3 |
| 72 | + ports: |
| 73 | + - "5432:5432" |
| 74 | + volumes: |
| 75 | + - db-data:/var/lib/postgresql/data |
| 76 | + networks: |
| 77 | + - server |
| 78 | + |
| 79 | +volumes: |
| 80 | + db-data: |
| 81 | + |
| 82 | +networks: |
| 83 | + server: |
0 commit comments