-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
52 lines (49 loc) · 1.65 KB
/
docker-compose.yml
File metadata and controls
52 lines (49 loc) · 1.65 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
services:
db:
image: postgres:16
restart: unless-stopped
environment:
POSTGRES_USER: ${POSTGRES_USER:-loopctl}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:?Set POSTGRES_PASSWORD in .env}
POSTGRES_DB: ${POSTGRES_DB:-loopctl_prod}
DB_APP_USER: ${DB_APP_USER:-loopctl_app}
DB_APP_PASSWORD: ${DB_APP_PASSWORD:?Set DB_APP_PASSWORD in .env}
DB_ADMIN_USER: ${DB_ADMIN_USER:-loopctl_admin}
DB_ADMIN_PASSWORD: ${DB_ADMIN_PASSWORD:?Set DB_ADMIN_PASSWORD in .env}
volumes:
- pgdata:/var/lib/postgresql/data
- ./deploy/init-db.sh:/docker-entrypoint-initdb.d/init-db.sh:ro
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER:-loopctl}"]
interval: 10s
timeout: 5s
retries: 5
app:
build: .
restart: unless-stopped
depends_on:
db:
condition: service_healthy
environment:
DATABASE_URL: "ecto://${DB_APP_USER:-loopctl_app}:${DB_APP_PASSWORD:?Set DB_APP_PASSWORD in .env}@db/${POSTGRES_DB:-loopctl_prod}"
ADMIN_DATABASE_URL: "ecto://${DB_ADMIN_USER:-loopctl_admin}:${DB_ADMIN_PASSWORD:?Set DB_ADMIN_PASSWORD in .env}@db/${POSTGRES_DB:-loopctl_prod}"
SECRET_KEY_BASE: ${SECRET_KEY_BASE:?Set SECRET_KEY_BASE in .env}
CLOAK_KEY: ${CLOAK_KEY:?Set CLOAK_KEY in .env}
PHX_HOST: ${PHX_HOST:-localhost}
PHX_SERVER: "true"
PORT: "4000"
expose:
- "4000"
nginx:
image: nginx:alpine
restart: unless-stopped
depends_on:
- app
ports:
- "8443:443"
- "8080:80"
volumes:
- ./deploy/nginx.conf:/etc/nginx/conf.d/default.conf:ro
- ./deploy/certs:/etc/nginx/certs:ro
volumes:
pgdata: