Files
chesscubing/docker-compose.yml

119 lines
3.7 KiB
YAML

services:
web:
build:
context: .
dockerfile: Dockerfile
container_name: chesscubing-web
depends_on:
auth:
condition: service_started
keycloak:
condition: service_started
ports:
- "${WEB_PORT:-8080}:80"
restart: unless-stopped
auth:
build:
context: .
dockerfile: Dockerfile.auth
container_name: chesscubing-auth
environment:
ASPNETCORE_URLS: http://+:8080
KEYCLOAK_BASE_URL: http://keycloak:8080/auth
KEYCLOAK_REALM: chesscubing
KEYCLOAK_CLIENT_ID: chesscubing-web
KEYCLOAK_ADMIN_USERNAME: ${KEYCLOAK_ADMIN_USER:-admin}
KEYCLOAK_ADMIN_PASSWORD: ${KEYCLOAK_ADMIN_PASSWORD:-admin}
SITE_DB_HOST: mysql
SITE_DB_PORT: 3306
SITE_DB_NAME: ${SITE_DB_NAME:-chesscubing_site}
SITE_DB_USER: ${SITE_DB_USER:-chesscubing}
SITE_DB_PASSWORD: ${SITE_DB_PASSWORD:-chesscubing}
depends_on:
keycloak-init:
condition: service_completed_successfully
keycloak:
condition: service_started
mysql:
condition: service_healthy
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: "${PUBLIC_BASE_URL:-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
keycloak-init:
image: quay.io/keycloak/keycloak:26.1.2
container_name: chesscubing-keycloak-init
entrypoint: ["/bin/sh", "/opt/keycloak/data/scripts/init-config.sh"]
environment:
KEYCLOAK_URL: http://keycloak:8080/auth
KEYCLOAK_REALM: chesscubing
KEYCLOAK_CLIENT_ID: chesscubing-web
KEYCLOAK_ADMIN_USERNAME: ${KEYCLOAK_ADMIN_USER:-admin}
KEYCLOAK_ADMIN_PASSWORD: ${KEYCLOAK_ADMIN_PASSWORD:-admin}
volumes:
- ./keycloak/scripts:/opt/keycloak/data/scripts:ro
depends_on:
keycloak:
condition: service_started
restart: "no"
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
mysql:
image: mysql:8.4
container_name: chesscubing-site-db
environment:
MYSQL_DATABASE: ${SITE_DB_NAME:-chesscubing_site}
MYSQL_USER: ${SITE_DB_USER:-chesscubing}
MYSQL_PASSWORD: ${SITE_DB_PASSWORD:-chesscubing}
MYSQL_ROOT_PASSWORD: ${SITE_DB_ROOT_PASSWORD:-change-me}
volumes:
- site-mysql-data:/var/lib/mysql
healthcheck:
test: ["CMD-SHELL", "mysqladmin ping -h 127.0.0.1 -u$${MYSQL_USER} -p$${MYSQL_PASSWORD} --silent"]
interval: 10s
timeout: 5s
retries: 8
restart: unless-stopped
volumes:
keycloak-postgres:
site-mysql-data: