54 lines
1.6 KiB
YAML
54 lines
1.6 KiB
YAML
services:
|
|
web:
|
|
build: .
|
|
container_name: chesscubing-web
|
|
depends_on:
|
|
keycloak:
|
|
condition: service_started
|
|
ports:
|
|
- "8080:80"
|
|
restart: unless-stopped
|
|
|
|
keycloak:
|
|
image: quay.io/keycloak/keycloak:26.1.2
|
|
container_name: chesscubing-keycloak
|
|
command: ["start-dev", "--import-realm"]
|
|
environment:
|
|
KC_DB: postgres
|
|
KC_DB_URL_HOST: postgres
|
|
KC_DB_URL_PORT: 5432
|
|
KC_DB_URL_DATABASE: ${KEYCLOAK_DB_NAME:-keycloak}
|
|
KC_DB_USERNAME: ${KEYCLOAK_DB_USER:-keycloak}
|
|
KC_DB_PASSWORD: ${KEYCLOAK_DB_PASSWORD:-keycloak}
|
|
KC_BOOTSTRAP_ADMIN_USERNAME: ${KEYCLOAK_ADMIN_USER:-admin}
|
|
KC_BOOTSTRAP_ADMIN_PASSWORD: ${KEYCLOAK_ADMIN_PASSWORD:-admin}
|
|
KC_PROXY_HEADERS: xforwarded
|
|
KC_HOSTNAME: http://localhost:8080/auth
|
|
KC_HTTP_RELATIVE_PATH: /auth
|
|
KC_HOSTNAME_STRICT: "false"
|
|
volumes:
|
|
- ./keycloak/realm:/opt/keycloak/data/import:ro
|
|
depends_on:
|
|
postgres:
|
|
condition: service_healthy
|
|
restart: unless-stopped
|
|
|
|
postgres:
|
|
image: postgres:16-alpine
|
|
container_name: chesscubing-keycloak-db
|
|
environment:
|
|
POSTGRES_DB: ${KEYCLOAK_DB_NAME:-keycloak}
|
|
POSTGRES_USER: ${KEYCLOAK_DB_USER:-keycloak}
|
|
POSTGRES_PASSWORD: ${KEYCLOAK_DB_PASSWORD:-keycloak}
|
|
volumes:
|
|
- keycloak-postgres:/var/lib/postgresql/data
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -U ${KEYCLOAK_DB_USER:-keycloak} -d ${KEYCLOAK_DB_NAME:-keycloak}"]
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 5
|
|
restart: unless-stopped
|
|
|
|
volumes:
|
|
keycloak-postgres:
|