-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-compose.yml
96 lines (89 loc) · 2.7 KB
/
docker-compose.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
version: '3.7'
services:
traefik:
image: traefik:v3.1.2
restart: unless-stopped
command:
- --api.insecure=true
- --providers.docker
- --providers.file.filename=/traefik_dynamic.yml # Reference the dynamic config file
- --experimental.plugins.jwt.modulename=github.com/Brainnwave/jwt-middleware
- --experimental.plugins.jwt.version=v1.2.1
ports:
- "80:80"
- "8080:8080"
networks:
- dachub
volumes:
# So that Traefik can listen to the Docker events
- /var/run/docker.sock:/var/run/docker.sock
- ./traefik_dynamic.yml:/traefik_dynamic.yml:ro
depends_on:
# Must wait for keycloak to start
- keycloak
geoserver:
image: docker.osgeo.org/geoserver:2.23.0
environment:
JAVA_OPTS: -Xmx1536M -XX:MaxPermSize=756M
CORS_ENABLED: true
CORS_ALLOWED_ORIGINS: "*"
CORS_ALLOWED_METHODS: "GET,POST,PUT,DELETE,HEAD,OPTIONS"
CORS_ALLOWED_HEADERS: "*"
networks:
- dachub
restart: unless-stopped
volumes:
- geoserver_data:/opt/geoserver_data
- geoserver_exts:/opt/additional_libs
labels:
- "traefik.enable=true"
- "traefik.http.routers.geoserver.rule=PathPrefix(`/geoserver`)"
- "traefik.http.routers.geoserver.middlewares=secure-api@file"
- "traefik.http.routers.backend.priority=6"
- "traefik.http.services.geoserver.loadbalancer.server.port=8080" # Internal port in the container
postgres:
image: postgres
restart: unless-stopped
networks:
- dachub
volumes:
- postgres_data:/var/lib/postgresql/data
environment:
POSTGRES_DB: keycloak_prod
POSTGRES_USER: keycloak
POSTGRES_PASSWORD: password
keycloak:
image: quay.io/keycloak/keycloak:20.0
restart: unless-stopped
networks:
- dachub
volumes:
- ./keycloak/dachub-realm-prod.json:/opt/keycloak/data/import/realm.json:ro
command:
- start-dev
- --http-relative-path /keycloak
- --import-realm
environment:
KEYCLOAK_ADMIN: admin
KEYCLOAK_ADMIN_PASSWORD: admin
KC_DB: postgres
KC_DB_URL_HOST: postgres
KC_DB_URL_DATABASE: keycloak_prod
KC_DB_USERNAME: keycloak
KC_DB_PASSWORD: password
depends_on:
- postgres
labels:
- "traefik.enable=true"
- "traefik.http.routers.keycloak.rule=PathPrefix(`/keycloak`)"
- "traefik.http.services.keycloak.loadbalancer.server.port=8080"
- "traefik.http.routers.keycloak.priority=10"
## By default this config uses default local driver,
## For custom volumes replace with volume driver configuration.
volumes:
postgres_data:
elasticsearch:
geoserver_data:
geoserver_exts:
networks:
dachub: