-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
97 lines (92 loc) · 2.19 KB
/
docker-compose.yml
File metadata and controls
97 lines (92 loc) · 2.19 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
services:
# Nginx reverse proxy
nginx:
build:
context: ./nginx
dockerfile: Dockerfile
container_name: divemap_nginx
restart: always
ports:
- "80:80"
depends_on:
- frontend
- backend
networks:
- divemap_network
# Backend API
backend:
build:
context: ./backend
dockerfile: Dockerfile
container_name: divemap_backend
restart: always
ports:
- 8000:8000
env_file:
- ".env"
environment:
- DATABASE_URL=mysql+pymysql://${MYSQL_USER:-divemap_user}:${MYSQL_PASSWORD:-divemap_password}@db:3306/divemap
- SECRET_KEY=${SECRET_KEY:-your-secret-key-change-in-production}
- OPENAI_API_KEY=${OPENAI_API_KEY:-foobar}
- LLM_PROVIDER=${LLM_PROVIDER:-openai}
- DEEPSEEK_API_KEY=${DEEPSEEK_API_KEY}
- LOG_LEVEL=INFO
volumes:
- ./backend:/app
- ./uploads:/app/uploads
depends_on:
- db
networks:
- divemap_network
security_opt:
- no-new-privileges:true
read_only: false
command: ["/app/startup.sh"]
# Frontend
frontend:
build:
context: ./frontend
dockerfile: Dockerfile.dev
container_name: divemap_frontend
restart: always
ports: []
volumes:
- ./frontend:/app
- /app/node_modules
env_file:
- "./frontend/.env"
environment:
- VITE_API_URL=${VITE_API_URL:-http://localhost}
- NODE_ENV=${NODE_ENV:-development}
depends_on:
- backend
networks:
- divemap_network
security_opt:
- no-new-privileges:true
read_only: false
# MySQL Database
db:
image: mysql:lts
container_name: divemap_db
restart: always
environment:
MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD:-rootpassword}
MYSQL_DATABASE: divemap
MYSQL_USER: ${MYSQL_USER:-divemap_user}
MYSQL_PASSWORD: ${MYSQL_PASSWORD:-divemap_password}
ports:
- "3306:3306"
volumes:
- mysql_data:/var/lib/mysql
- ./database/init.sql:/docker-entrypoint-initdb.d/init.sql
networks:
- divemap_network
security_opt:
- no-new-privileges:true
read_only: false
volumes:
mysql_data:
networks:
divemap_network:
driver: bridge