-
Notifications
You must be signed in to change notification settings - Fork 0
/
docker-compose.yml
199 lines (188 loc) · 7.32 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
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
services:
db_test:
build:
# Custom image for file permissions
# context: ./docker/mysql
context: ./docker/postgres
#context: ./docker/mariadb
args:
USER_UID: ${USER_UID}
networks:
- default
volumes:
- "./.data/db_test:/var/lib/mysql:delegated"
- "./docker/mysql/performances.cnf:/etc/mysql/conf.d/performances.cnf"
- "./.data/pgsql_test:/var/lib/postgresql/data:delegated"
environment:
MYSQL_RANDOM_ROOT_PASSWORD: 1
MYSQL_DATABASE: db_name_test
MYSQL_USER: db_user
MYSQL_PASSWORD: db_password
# Enable easy switching with Postgres
PGDATA: /var/lib/postgresql/data
POSTGRES_USER: db_user
POSTGRES_PASSWORD: db_password
POSTGRES_DB: db_name_test
db:
build:
# Custom image for file permissions
context: ./docker/mysql
args:
USER_UID: ${USER_UID}
ports:
- ${PUBLIC_DB_PORT}:3306/tcp
networks:
- default
volumes:
- "./.data/db:/var/lib/mysql:delegated"
- "./docker/mysql/performances.cnf:/etc/mysql/conf.d/performances.cnf"
environment:
MYSQL_RANDOM_ROOT_PASSWORD: 1
MYSQL_DATABASE: db_name
MYSQL_USER: db_user
MYSQL_PASSWORD: db_password
pma:
image: phpmyadmin/phpmyadmin
ports:
- ${PUBLIC_PMA_PORT}:80/tcp
environment:
MYSQL_RANDOM_ROOT_PASSWORD: 1
MYSQL_DATABASE: db_name
MYSQL_HOST: db
MYSQL_USER: db_user
MYSQL_PASSWORD: db_password
depends_on:
- db
networks:
- frontproxynet
- default
labels:
- "traefik.enable=true"
- "traefik.http.services.${APP_NAMESPACE}_pma.loadbalancer.server.scheme=http"
- "traefik.http.services.${APP_NAMESPACE}_pma.loadbalancer.server.port=80"
- "traefik.http.services.${APP_NAMESPACE}_pma.loadbalancer.passhostheader=true"
# Listen HTTP
- "traefik.http.routers.${APP_NAMESPACE}_pma.entrypoints=http"
- "traefik.http.routers.${APP_NAMESPACE}_pma.rule=Host(${HOSTNAME_PMA})"
- "traefik.http.routers.${APP_NAMESPACE}_pma.service=${APP_NAMESPACE}_pma"
solr:
build:
# Custom image for file permissions
context: ./docker/solr
args:
USER_UID: ${USER_UID}
ports:
- "${PUBLIC_SOLR_PORT}:8983/tcp"
volumes:
- "solr_data:/var/solr:delegated"
environment:
SOLR_UID: ${USER_UID}
SOLR_GID: ${USER_UID}
command:
- solr-precreate
- ${SOLR_CORE_NAME}
networks:
- frontproxynet
- default
labels:
- "traefik.enable=true"
- "traefik.http.services.${APP_NAMESPACE}_solr.loadbalancer.server.scheme=http"
- "traefik.http.services.${APP_NAMESPACE}_solr.loadbalancer.server.port=8983"
- "traefik.http.services.${APP_NAMESPACE}_solr.loadbalancer.passhostheader=true"
# Listen HTTP
- "traefik.http.routers.${APP_NAMESPACE}_solr.entrypoints=http"
- "traefik.http.routers.${APP_NAMESPACE}_solr.rule=Host(${HOSTNAME_SOLR})"
- "traefik.http.routers.${APP_NAMESPACE}_solr.service=${APP_NAMESPACE}_solr"
redis:
image: redis:7-alpine
networks:
- default
app: &app_template
# Need to pass all vars to docker env for Crontab and supervisor scripts
env_file: "./.env.local"
build:
context: ./docker/php82-fpm-alpine
args:
USER_UID: ${USER_UID}
depends_on:
- db
- solr
- redis
volumes:
- ./:/var/www/html:cached
networks:
- default
environment:
APP_CACHE: ${APP_CACHE}
TRUSTED_PROXIES: ${TRUSTED_PROXIES}
USER_UID: ${USER_UID}
DEFAULT_GATEWAY: ${DEFAULT_GATEWAY}
worker:
<<: *app_template
deploy:
replicas: 1
entrypoint: ["php", "/var/www/html/bin/console", "messenger:consume", "async", "--time-limit=60"]
restart: unless-stopped
cron:
<<: *app_template
# https://github.com/dubiousjim/dcron/issues/13#issuecomment-1406937781
init: true
entrypoint: ["crond", "-f", "-L", "15"]
nginx:
image: roadiz/nginx-alpine:latest
ports:
- ${PUBLIC_APP_PORT}:80/tcp
depends_on:
- app
volumes:
- ./:/var/www/html:cached
networks:
- default
- frontproxynet
labels:
- "traefik.enable=true"
- "traefik.http.services.${APP_NAMESPACE}.loadbalancer.server.scheme=http"
- "traefik.http.services.${APP_NAMESPACE}.loadbalancer.server.port=80"
- "traefik.http.services.${APP_NAMESPACE}.loadbalancer.passhostheader=true"
# - "traefik.http.services.${APP_NAMESPACE}.loadbalancer.healthcheck.path=/health-check"
# - "traefik.http.services.${APP_NAMESPACE}.loadbalancer.healthcheck.interval=10s"
# - "traefik.http.services.${APP_NAMESPACE}.loadbalancer.healthcheck.timeout=3s"
# - "traefik.http.services.${APP_NAMESPACE}.loadbalancer.healthcheck.headers.x-health-check=${APP_HEALTH_CHECK_TOKEN}"
# Listen HTTP
- "traefik.http.routers.${APP_NAMESPACE}.entrypoints=http"
- "traefik.http.routers.${APP_NAMESPACE}.rule=Host(${HOSTNAME})"
- "traefik.http.routers.${APP_NAMESPACE}.service=${APP_NAMESPACE}"
# Listen HTTPS
- "traefik.http.routers.${APP_NAMESPACE}_secure.entrypoints=https"
- "traefik.http.routers.${APP_NAMESPACE}_secure.rule=Host(${HOSTNAME})"
- "traefik.http.routers.${APP_NAMESPACE}_secure.tls=true"
- "traefik.http.routers.${APP_NAMESPACE}_secure.service=${APP_NAMESPACE}"
mailer:
image: mailhog/mailhog
ports:
- ${PUBLIC_MAILER_PORT}:8025/tcp
- ${SMTP_MAILER_PORT}:1025/tcp
networks:
- frontproxynet
- default
labels:
- "traefik.enable=true"
- "traefik.http.services.${APP_NAMESPACE}_mailer.loadbalancer.server.scheme=http"
- "traefik.http.services.${APP_NAMESPACE}_mailer.loadbalancer.server.port=8025"
- "traefik.http.services.${APP_NAMESPACE}_mailer.loadbalancer.passhostheader=true"
# Listen HTTP
- "traefik.http.routers.${APP_NAMESPACE}_mailer.entrypoints=http"
- "traefik.http.routers.${APP_NAMESPACE}_mailer.rule=Host(${HOSTNAME_MAILER})"
- "traefik.http.routers.${APP_NAMESPACE}_mailer.service=${APP_NAMESPACE}_mailer"
networks:
frontproxynet:
external: true
# If you need to use port forwarding, fixing default gateway can be useful
# to keep same host IP address between service restarts
default:
ipam:
driver: default
config:
- subnet: ${DEFAULT_GATEWAY}/16
volumes:
solr_data: