-
-
Notifications
You must be signed in to change notification settings - Fork 48
/
Copy pathdocker-compose.yml
executable file
·175 lines (165 loc) · 6.25 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
version: 3.9
services:
nestify:
container_name: nestify
env_file: env/.env.${ENV}
build:
context: .
dockerfile: ./docker/dev.Dockerfile
image: nestify
depends_on:
- traefik
- redis
- rabbitmq
- database
restart: unless-stopped
command: npm run start:dev
labels:
- traefik.enable=true
- traefik.http.routers.nestify.rule=Host(`${API_URL}`)
- traefik.http.services.nestify.loadbalancer.server.port=3000
- traefik.http.routers.nestify.entrypoints=websecure
- traefik.http.routers.nestify.tls=true
- traefik.http.routers.nestify.tls.certresolver=myresolver
- traefik.http.middlewares.test-ratelimit.ratelimit.average=100
- traefik.http.middlewares.test-ratelimit.ratelimit.burst=50
- traefik.http.middlewares.test-ratelimit.ratelimit.period=1m
- traefik.http.middlewares.traefik-headers.headers.framedeny=true
- traefik.http.middlewares.traefik-headers.headers.browserxssfilter=true
- traefik.http.middlewares.traefik-headers.headers.contentTypeNosniff=true
- traefik.http.middlewares.test-compress.compress=true
- traefik.http.middlewares.traefik-headers.headers.permissionsPolicy=camera 'none'; geolocation 'none'; microphone 'none'; payment 'none'; usb 'none'; vr 'none';
stdin_open: true
tty: true
networks:
- nestify-network
volumes:
- .:/usr/src/app
- /usr/src/app/node_modules
traefik:
image: traefik:v2.10.1
container_name: traefik
command:
# Enable Docker in Traefik, so that it reads labels from Docker services
- --providers.docker=true
# Do not expose all Docker services, only the ones explicitly exposed
- --providers.docker.exposedbydefault=false
# Disable Docker Swarm mode for local development
# - --providers.docker.swarmmode
# Enable the access log, with HTTP requests
- --accesslog
# Enable the Traefik log, for configurations and errors
- --log
# Enable the Dashboard and API
- --api
# Enable the Dashboard and API in insecure mode for local development
- --api.insecure=true
# Define HTTP entrypoint on port 80
- --entrypoints.web.address=:80
# Define HTTPS entrypoint on port 443
- --entrypoints.websecure.address=:443
# Enable Let's Encrypt certificate resolver
- --certificatesresolvers.myresolver.acme.tlschallenge=true
# Email address used for Let's Encrypt registration
# Path to store Let's Encrypt certificates
- --certificatesresolvers.myresolver.acme.storage=/letsencrypt/acme.json
# Redirect HTTP requests to HTTPS
- --providers.middlewares.httpsredirect.redirectscheme.scheme=https
# Enable basic authentication for Traefik dashboard
- --api.dashboard.auth.basic.users=user:$$apr1$$<encrypted-password-here>
# Enable Let's Encrypt staging environment for local development , remove this line for production
- --certificatesresolvers.myresolver.acme.caserver=https://acme-staging-v02.api.letsencrypt.org/directory
labels:
- traefik.enable=true
networks:
- nestify-network
ports:
- "443:443"
- "80:80"
- "8080:8080"
volumes:
- ./letsencrypt:/letsencrypt
- /var/run/docker.sock:/var/run/docker.sock:ro
redis:
container_name: redis
image: redis:7.0.11-alpine
env_file: env/.env.${ENV}
restart: always
depends_on:
- traefik
ports:
- "6379:6379"
networks:
- nestify-network
command: redis-server --loglevel warning --requirepass ${PASSWORD}
volumes:
- redis-data:/data
rabbitmq:
container_name: rabbitmq
image: rabbitmq:3.12.0-management-alpine
env_file: env/.env.${ENV}
networks:
- nestify-network
depends_on:
- traefik
environment:
- RABBITMQ_DEFAULT_USER=nestify
- RABBITMQ_DEFAULT_PASS=${PASSWORD}
ports:
- "5672:5672"
- "15672:15672"
volumes:
- rabbitmq-data:/var/lib/rabbitmq/mnesia/
database:
container_name: database
image: postgres:15.3-alpine
restart: unless-stopped
env_file: env/.env.${ENV}
volumes:
- postgres_data:/var/lib/postgresql/data/
depends_on:
- traefik
environment:
- POSTGRES_USER=${DB_USERNAME}
- POSTGRES_PASSWORD=${DB_PASSWORD}
- POSTGRES_DB=${DB_DATABASE}
networks:
- nestify-network
ports:
- "5432:5432"
pgadmin:
container_name: pgadmin4_container
image: dpage/pgadmin4:7.3
env_file: env/.env.${ENV}
restart: unless-stopped
environment:
- PGADMIN_DEFAULT_PASSWORDsecret
- PGADMIN_LISTEN_PORT=80
ports:
- "8090:8090"
volumes:
- pgadmin-data:/var/lib/pgadmin
depends_on:
- traefik
networks:
- nestify-network
labels:
- traefik.enable=true
# Set routing rule for HTTPS requests
- traefik.http.routers.web.rule=Host(`${API_URL}`)
# Use HTTPS entrypoint for this service
- traefik.http.routers.web.entrypoints=websecure
# Enable TLS for this service
- traefik.http.routers.web.tls=true
# Use the myresolver certificate resolver for this service
- traefik.http.routers.web.tls.certresolver=myresolver
volumes:
redis-data:
rabbitmq-data:
postgres_data:
pgadmin-data:
networks:
nestify-network:
name: nestify-network