-
Notifications
You must be signed in to change notification settings - Fork 1
/
docker-compose.yml
146 lines (136 loc) · 3.5 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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
# Copyright (C) 2022 B3Partners B.V.
#
# SPDX-License-Identifier: MIT
name: 'tailormap-ci'
volumes:
postgis-db:
sqlserver-db:
oracle-db:
solr-data:
networks:
tailormap-data:
name: tailormap-data
services:
postgres:
container_name: postgres
image: postgres:15-alpine
environment:
POSTGRES_USER: tailormap
POSTGRES_PASSWORD: tailormap
POSTGRES_DB: tailormap
ports:
- "127.0.0.1:5432:5432"
networks:
- tailormap-data
healthcheck:
test: su postgres -c pg_isready
interval: 15s
timeout: 5s
retries: 5
start_period: 45s
restart: unless-stopped
postgis:
container_name: postgis
image: docker.b3p.nl/b3partners/tailormap-data_postgis:snapshot
environment:
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-fa6efb5b-075b-4b7b-aab0-96108cd77e76}
GEODATA_PASSWORD: ${GEODATA_PASSWORD:-980f1c8A-25933b2}
volumes:
- postgis-db:/var/lib/postgresql/data
ports:
- "127.0.0.1:54322:5432"
networks:
- tailormap-data
healthcheck:
interval: 1m
timeout: 5s
retries: 5
start_period: 1m
test: su postgres -c pg_isready
restart: unless-stopped
sqlserver:
container_name: sqlserver
image: docker.b3p.nl/b3partners/tailormap-data_sqlserver:snapshot
environment:
SA_PASSWORD: ${SA_PASSWORD:-fa6efb5b-075b-4b7b-aab0-96108cd77e76}
GEODATA_PASSWORD: ${GEODATA_PASSWORD:-980f1c8A-25933b2}
ACCEPT_EULA: Y
volumes:
- sqlserver-db:/var/opt/mssql
ports:
- "127.0.0.1:1433:1433"
networks:
- tailormap-data
healthcheck:
interval: 1m
timeout: 5s
retries: 5
start_period: 1m
test: /opt/mssql-tools/bin/sqlcmd -U sa -P $$SA_PASSWORD -Q "select 1" -b -o /dev/null
restart: unless-stopped
oracle:
container_name: oracle
image: docker.b3p.nl/b3partners/tailormap-data_oracle:snapshot
environment: # Note Oracle has default maximum password length of 16!
ORACLE_PASSWORD: ${ORACLE_PASSWORD:-fa6efb5b-075b-4b}
# this user is created in XEPDB1, not in XE
APP_USER: "geodata"
APP_USER_PASSWORD: ${GEODATA_PASSWORD:-980f1c8A-25933b2}
GEODATA_PASSWORD: ${GEODATA_PASSWORD:-980f1c8A-25933b2}
volumes:
- oracle-db:/opt/oracle/oradata
ports:
- "127.0.0.1:1521:1521"
networks:
- tailormap-data
labels:
traefik.enable: false
healthcheck:
interval: 1m
timeout: 5s
retries: 5
start_period: 1m
test: healthcheck.sh
restart: unless-stopped
solr:
container_name: solr
depends_on:
- postgis
- oracle
- sqlserver
image: solr:latest
environment:
TZ: Europe/Amsterdam
SOLR_HEAP: 1g
volumes:
- solr-data:/var/solr
ports:
- "127.0.0.1:8983:8983"
networks:
- tailormap-data
restart: unless-stopped
command:
- solr-precreate
- tailormap
solr-status:
container_name: solr-status
depends_on:
- solr
profiles:
# in the CI scenario, we don't want to run the solr-exporter
- monitoring-enabled
image: solr:latest
ports:
- "127.0.0.1:9854:9854"
networks:
- tailormap-data
environment:
TZ: Europe/Amsterdam
PORT: 9854
SCRAPE_INTERVAL: 15
SOLR_URL: http://solr:8983/solr/
restart: unless-stopped
command:
# this script should be in the path for the current user
# /opt/solr-9.5.0/prometheus-exporter/bin/solr-exporter
- solr-exporter