forked from teamdeeson/d8-quickstart
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
152 lines (141 loc) · 3.95 KB
/
docker-compose.yml
File metadata and controls
152 lines (141 loc) · 3.95 KB
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
version: "3"
services:
mariadb:
image: $MARIADB_TAG
container_name: "${PROJECT_NAME}_mariadb"
stop_grace_period: 30s
environment:
MYSQL_ROOT_PASSWORD: $DB_ROOT_PASSWORD
MYSQL_DATABASE: $DB_NAME
MYSQL_USER: $DB_USER
MYSQL_PASSWORD: $DB_PASSWORD
# ports:
# - "3307:3306"
volumes:
# - ./mariadb-init:/docker-entrypoint-initdb.d # Place init .sql file(s) here.
- ./.persist/mysql:/var/lib/mysql:delegated # I want to manage volumes manually.
networks:
- default
php:
image: $PHP_TAG
container_name: "${PROJECT_NAME}_php"
environment:
DOCKER_LOCAL: 1
D4D_HOSTNAME: ${PROJECT_BASE_URL}
PHP_SENDMAIL_PATH: /usr/sbin/sendmail -t -i -S mailhog:1025
DB_HOST: $DB_HOST
DB_USER: $DB_USER
DB_PASSWORD: $DB_PASSWORD
DB_NAME: $DB_NAME
DB_DRIVER: $DB_DRIVER
PHP_XDEBUG: 1
PHP_XDEBUG_DEFAULT_ENABLE: 1
PHP_XDEBUG_REMOTE_CONNECT_BACK: 0 # This is needed to respect remote.host setting bellow
PHP_XDEBUG_REMOTE_HOST: "10.254.254.254" # You will also need to 'sudo ifconfig lo0 alias 10.254.254.254'
PHP_IDE_CONFIG: "serverName=drupal" # Needed for xdebug for drush commands.
volumes:
- ./:/var/www/html:cached
- ./.persist/public:/var/www/html/docroot/sites/default/files:delegated
- ./.persist/private:/private:delegated
tmpfs: /tmp
networks:
- default
nginx:
image: $NGINX_TAG
container_name: "${PROJECT_NAME}_nginx"
depends_on:
- php
environment:
NGINX_STATIC_CONTENT_OPEN_FILE_CACHE: "off"
NGINX_ERROR_LOG_LEVEL: debug
NGINX_BACKEND_HOST: php
NGINX_SERVER_ROOT: /var/www/html/docroot
volumes:
- ./:/var/www/html:cached
- ./.persist/public:/var/www/html/docroot/sites/default/files:delegated
tmpfs: /tmp
networks:
- default
- proxy
labels:
- 'traefik.docker.network=proxy'
- 'traefik.port=80'
- 'traefik.frontend.rule=Host:${PROJECT_BASE_URL}'
solr:
image: $SOLR_TAG
container_name: "${PROJECT_NAME}_solr"
environment:
SOLR_HEAP: 1024m
volumes:
- ./.persist/solr:/opt/solr/server/solr/core1:delegated
networks:
- default
- proxy
labels:
- 'traefik.docker.network=proxy'
- 'traefik.port=8983'
- 'traefik.frontend.rule=Host:solr.${PROJECT_BASE_URL}'
mailhog:
image: mailhog/mailhog
container_name: "${PROJECT_NAME}_mailhog"
networks:
- default
- proxy
labels:
- 'traefik.docker.network=proxy'
- 'traefik.port=8025'
- 'traefik.frontend.rule=Host:mailhog.${PROJECT_BASE_URL}'
# memcached:
# container_name: "${PROJECT_NAME}_memcached"
# image: $MEMCACHED_TAG
# networks:
# - default
redis:
container_name: "${PROJECT_NAME}_redis"
image: $REDIS_TAG
networks:
- default
fe-node:
image: deeson/fe-node
container_name: "${PROJECT_NAME}_fe-node"
depends_on:
- 'fe-php'
volumes:
- .:/app:delegated
working_dir: /app
environment:
DOCKER_LOCAL: 1
command: sh -c 'yarn install && yarn start'
networks:
- default
- proxy
labels:
- 'traefik.docker.network=proxy'
- 'traefik.port=80'
- 'traefik.frontend.rule=Host:frontend.${PROJECT_BASE_URL}'
fe-php:
image: deeson/fe-php
container_name: "${PROJECT_NAME}_fe-php"
volumes:
- .:/app:delegated
working_dir: /app
environment:
DOCKER_LOCAL: 1
command: sh -c 'composer install && node_modules/.bin/deeson-router-start.sh'
networks:
- default
# varnish:
# image: wodby/drupal-varnish:4.1-2.1.0
# depends_on:
# - nginx
# environment:
# VARNISH_SECRET: secret
# VARNISH_BACKEND_HOST: nginx
# VARNISH_BACKEND_PORT: 80
# labels:
# - 'traefik.backend=varnish'
# - 'traefik.port=6081'
# - 'traefik.frontend.rule=Host:varnish.localhost'
networks:
proxy:
external: true