122 lines
3.6 KiB
YAML
122 lines
3.6 KiB
YAML
# ==========================================
|
||
# GardenPlan – Docker Compose (Development)
|
||
# ==========================================
|
||
|
||
services:
|
||
# --------------------------------------------------
|
||
# PHP-FPM – Symfony Backend
|
||
# --------------------------------------------------
|
||
php-fpm:
|
||
build:
|
||
context: ./Infra/php-fpm
|
||
dockerfile: Dockerfile
|
||
container_name: gardenplan-php-fpm
|
||
restart: unless-stopped
|
||
working_dir: /var/www/html
|
||
volumes:
|
||
- ./Backend:/var/www/html:z
|
||
- phpsocket:/var/run/php
|
||
networks:
|
||
- gardenplan-network
|
||
depends_on:
|
||
database:
|
||
condition: service_healthy
|
||
|
||
# --------------------------------------------------
|
||
# Nginx – Webserver & Reverse Proxy
|
||
# --------------------------------------------------
|
||
nginx:
|
||
image: nginx:1.25-alpine
|
||
container_name: gardenplan-nginx
|
||
restart: unless-stopped
|
||
ports:
|
||
- "80:80"
|
||
- "443:443"
|
||
volumes:
|
||
- ./Infra/nginx/default.conf:/etc/nginx/conf.d/default.conf:z
|
||
- ./Backend/public:/var/www/html/public:ro,z
|
||
- nginx_cache:/var/cache/nginx
|
||
networks:
|
||
- gardenplan-network
|
||
depends_on:
|
||
- php-fpm
|
||
|
||
# --------------------------------------------------
|
||
# PostgreSQL – Datenbank
|
||
# --------------------------------------------------
|
||
database:
|
||
image: postgres:16-alpine
|
||
container_name: gardenplan-database
|
||
restart: unless-stopped
|
||
ports:
|
||
- "5432:5432"
|
||
environment:
|
||
POSTGRES_DB: ${POSTGRES_DB:-gardenplan}
|
||
POSTGRES_USER: ${POSTGRES_USER:-symfony}
|
||
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-changeme}
|
||
PGDATA: /var/lib/postgresql/data/pgdata
|
||
volumes:
|
||
- postgres_data:/var/lib/postgresql/data
|
||
- ./Infra/database/init:/docker-entrypoint-initdb.d:z
|
||
networks:
|
||
- gardenplan-network
|
||
healthcheck:
|
||
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER:-symfony} -d ${POSTGRES_DB:-gardenplan}"]
|
||
interval: 10s
|
||
timeout: 5s
|
||
retries: 5
|
||
start_period: 30s
|
||
|
||
# --------------------------------------------------
|
||
# Keycloak – Identity Provider (OIDC / JWT)
|
||
# --------------------------------------------------
|
||
keycloak:
|
||
image: quay.io/keycloak/keycloak:24.0
|
||
container_name: gardenplan-keycloak
|
||
restart: unless-stopped
|
||
ports:
|
||
- "8080:8080"
|
||
environment:
|
||
KEYCLOAK_ADMIN: ${KEYCLOAK_ADMIN:-admin}
|
||
KEYCLOAK_ADMIN_PASSWORD: ${KEYCLOAK_ADMIN_PASSWORD:-adminsecret}
|
||
KC_DATABASE: postgres
|
||
KC_DATABASE_URL: jdbc:postgresql://database:5432/keycloak_db
|
||
KC_DATABASE_USERNAME: keycloak
|
||
KC_DATABASE_PASSWORD: keycloak_secret
|
||
KC_HTTP_RELATIVE_PATH: /auth
|
||
KC_HOSTNAME: localhost
|
||
KC_HOSTNAME_STRICT: "false"
|
||
KC_FEATURES: scripts
|
||
command: start-dev
|
||
volumes:
|
||
- ./Infra/keycloak/realm-export.json:/opt/keycloak/data/import/realm-export.json:z
|
||
networks:
|
||
- gardenplan-network
|
||
depends_on:
|
||
database:
|
||
condition: service_healthy
|
||
|
||
# --------------------------------------------------
|
||
# Keycloak Database (getrennt, falls gewünscht)
|
||
# Hier verwenden wir die Haupt-DB mit eigenem Schema
|
||
# Alternative: extra DB-Container – hier vereinfacht
|
||
# --------------------------------------------------
|
||
|
||
# ==========================================
|
||
# Volumes
|
||
# ==========================================
|
||
volumes:
|
||
postgres_data:
|
||
driver: local
|
||
phpsocket:
|
||
driver: local
|
||
nginx_cache:
|
||
driver: local
|
||
|
||
# ==========================================
|
||
# Networks
|
||
# ==========================================
|
||
networks:
|
||
gardenplan-network:
|
||
driver: bridge
|