36 lines
1.1 KiB
Docker
36 lines
1.1 KiB
Docker
# DOMAIN=example.com docker stack deploy -c keycloak.yml keycloak
|
|
# chown -R 1000:1000 data
|
|
|
|
services:
|
|
web:
|
|
image: keycloak/keycloak:${VERSION:-26.0.5}
|
|
command: start-dev
|
|
environment:
|
|
- KC_PROXY_HEADERS=xforwarded
|
|
- KC_BOOTSTRAP_ADMIN_USERNAME=${ADMIN_USERNAME:-admin}
|
|
- KC_BOOTSTRAP_ADMIN_PASSWORD=${ADMIN_PASSWORD:-myp@ssw0rd}
|
|
volumes:
|
|
- ${VOLUME_PATH}data:/opt/keycloak/data
|
|
- ${VOLUME_PATH}providers:/opt/keycloak/providers
|
|
deploy:
|
|
labels:
|
|
- traefik.enable=true
|
|
- traefik.http.routers.keycloak-${NUMBER:-1}.rule=Host(`${DOMAIN:-keycloak.localhost}`)
|
|
- traefik.http.routers.keycloak-${NUMBER:-1}.entrypoints=${SCHEME:-https}
|
|
- traefik.http.routers.keycloak-${NUMBER:-1}.service=keycloak-${NUMBER:-1}
|
|
- traefik.http.routers.keycloak-${NUMBER:-1}.tls.certresolver=letsencrypt
|
|
- traefik.http.services.keycloak-${NUMBER:-1}.loadbalancer.server.port=8080
|
|
networks:
|
|
- internal
|
|
- traefik
|
|
|
|
volumes:
|
|
data:
|
|
|
|
networks:
|
|
internal:
|
|
driver: overlay
|
|
attachable: true
|
|
traefik:
|
|
external: true
|
|
name: traefik-net
|