-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
77 lines (73 loc) · 2.9 KB
/
docker-compose.yml
File metadata and controls
77 lines (73 loc) · 2.9 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
name: nexus
services:
nexus:
build:
context: .
dockerfile: docker/Dockerfile
image: nexus-dev:latest
restart: unless-stopped
ports:
- "${FRONTEND_PORT:-3200}:3200"
- "${BACKEND_PORT:-8000}:8000"
# Port 4200 (ng serve) is internal — accessed via nginx proxy on 3200
# Port 6001 (Reverb) is proxied through nginx at /app — no direct exposure needed
environment:
APP_URL: "${APP_URL:-http://localhost:8000}"
APP_AUTH: "${APP_AUTH:-token}"
DB_HOST: db
DB_PORT: 3306
DB_DATABASE: "${DB_DATABASE:-nexus}"
DB_USERNAME: "${DB_USERNAME:-nexus}"
DB_PASSWORD: "${DB_PASSWORD:-nexus}"
ADMIN_EMAIL: "${ADMIN_EMAIL:-admin@example.com}"
ADMIN_PASSWORD: "${ADMIN_PASSWORD:-changeme}"
MAIL_MAILER: "${MAIL_MAILER:-log}"
MAIL_HOST: "${MAIL_HOST:-}"
MAIL_PORT: "${MAIL_PORT:-587}"
MAIL_FROM_ADDRESS: "${MAIL_FROM_ADDRESS:-noreply@example.com}"
KEYCLOAK_BASE_URL: "${KEYCLOAK_BASE_URL:-}"
KEYCLOAK_REALM: "${KEYCLOAK_REALM:-}"
KEYCLOAK_CLIENT_ID: "${KEYCLOAK_CLIENT_ID:-}"
KEYCLOAK_REALM_PUBLIC_KEY: "${KEYCLOAK_REALM_PUBLIC_KEY:-}"
LOG_LEVEL: "${LOG_LEVEL:-debug}"
REVERB_APP_ID: "${REVERB_APP_ID:-nexus}"
REVERB_APP_KEY: "${REVERB_APP_KEY:-nexus-key}"
REVERB_APP_SECRET: "${REVERB_APP_SECRET:-nexus-secret}"
REVERB_HOST: "0.0.0.0"
REVERB_PORT: "6001"
REVERB_SCHEME: "${REVERB_SCHEME:-http}"
volumes:
- ./backend:/var/www/backend
- ./frontend:/var/www/frontend
- backend_vendor:/var/www/backend/vendor # persists composer packages
- frontend_modules:/var/www/frontend/node_modules # persists npm packages
- storage_data:/var/www/backend/storage
- ./docker/nginx.dev.conf:/etc/nginx/nginx.conf
- ./docker/supervisord.dev.conf:/etc/supervisor/conf.d/supervisord.conf
- ./docker/ng-proxy.conf.json:/etc/nexus/ng-proxy.conf.json
depends_on:
db:
condition: service_healthy
db:
image: mariadb:11
restart: unless-stopped
ports:
- "${DB_PORT_HOST:-3308}:3306"
environment:
MYSQL_DATABASE: "${DB_DATABASE:-nexus}"
MYSQL_USER: "${DB_USERNAME:-nexus}"
MYSQL_PASSWORD: "${DB_PASSWORD:-nexus}"
MYSQL_ROOT_PASSWORD: "${DB_ROOT_PASSWORD:-nexus_root}"
volumes:
- db_data:/var/lib/mysql
healthcheck:
test: ["CMD", "healthcheck.sh", "--connect", "--innodb_initialized"]
start_period: 10s
interval: 5s
timeout: 5s
retries: 10
volumes:
db_data:
storage_data:
backend_vendor:
frontend_modules: