Files
storycove/docker-compose.yml
2025-09-21 15:08:20 +02:00

157 lines
4.3 KiB
YAML

networks:
storycove-network:
driver: bridge
services:
nginx:
image: nginx:alpine
ports:
- "6925:80"
volumes:
- images_data:/app/images:ro
configs:
- source: nginx_config
target: /etc/nginx/nginx.conf
depends_on:
- frontend
- backend
networks:
- storycove-network
frontend:
build: ./frontend
environment:
- NEXT_PUBLIC_API_URL=${NEXT_PUBLIC_API_URL:-/api}
depends_on:
- backend
networks:
- storycove-network
backend:
build: ./backend
environment:
- SPRING_DATASOURCE_URL=jdbc:postgresql://postgres:5432/storycove
- SPRING_DATASOURCE_USERNAME=storycove
- SPRING_DATASOURCE_PASSWORD=${DB_PASSWORD}
- JWT_SECRET=${JWT_SECRET}
- OPENSEARCH_HOST=opensearch
- OPENSEARCH_PORT=9200
- OPENSEARCH_SCHEME=http
- OPENSEARCH_USERNAME=
- OPENSEARCH_PASSWORD=
- OPENSEARCH_SSL_VERIFICATION=false
- OPENSEARCH_TRUST_ALL_CERTS=true
- SEARCH_ENGINE=${SEARCH_ENGINE:-opensearch}
- IMAGE_STORAGE_PATH=/app/images
- APP_PASSWORD=${APP_PASSWORD}
- STORYCOVE_CORS_ALLOWED_ORIGINS=${STORYCOVE_CORS_ALLOWED_ORIGINS:-http://localhost:3000,http://localhost:6925}
volumes:
- images_data:/app/images
- library_config:/app/config
depends_on:
- postgres
- opensearch
networks:
- storycove-network
postgres:
image: postgres:15-alpine
# No port mapping - only accessible within the Docker network
#ports:
# - "5432:5432"
environment:
- POSTGRES_DB=storycove
- POSTGRES_USER=storycove
- POSTGRES_PASSWORD=${DB_PASSWORD}
volumes:
- postgres_data:/var/lib/postgresql/data
networks:
- storycove-network
opensearch:
image: opensearchproject/opensearch:3.2.0
# No port mapping - only accessible within the Docker network
environment:
- cluster.name=storycove-opensearch
- node.name=opensearch-node
- discovery.type=single-node
- bootstrap.memory_lock=false
- "OPENSEARCH_JAVA_OPTS=-Xms512m -Xmx512m"
- "DISABLE_INSTALL_DEMO_CONFIG=true"
- "DISABLE_SECURITY_PLUGIN=true"
ulimits:
memlock:
soft: -1
hard: -1
nofile:
soft: 65536
hard: 65536
volumes:
- opensearch_data:/usr/share/opensearch/data
networks:
- storycove-network
restart: unless-stopped
opensearch-dashboards:
image: opensearchproject/opensearch-dashboards:3.2.0
ports:
- "5601:5601" # Expose OpenSearch Dashboard
environment:
- OPENSEARCH_HOSTS=http://opensearch:9200
- "DISABLE_SECURITY_DASHBOARDS_PLUGIN=true"
depends_on:
- opensearch
networks:
- storycove-network
volumes:
postgres_data:
opensearch_data:
images_data:
library_config:
configs:
nginx_config:
content: |
events {
worker_connections 1024;
}
http {
upstream frontend {
server frontend:3000;
}
upstream backend {
server backend:8080;
}
server {
listen 80;
client_max_body_size 256M;
location / {
proxy_pass http://frontend;
proxy_http_version 1.1;
proxy_set_header Upgrade $$http_upgrade;
proxy_set_header Connection upgrade;
proxy_set_header Host $$host;
proxy_set_header X-Real-IP $$remote_addr;
proxy_set_header X-Forwarded-For $$proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $$scheme;
proxy_cache_bypass $$http_upgrade;
}
location /api/ {
proxy_pass http://backend/api/;
proxy_set_header Host $$host;
proxy_set_header X-Real-IP $$remote_addr;
proxy_set_header X-Forwarded-For $$proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $$scheme;
proxy_connect_timeout 60s;
proxy_send_timeout 60s;
proxy_read_timeout 60s;
}
location /images/ {
alias /app/images/;
expires 1y;
add_header Cache-Control public;
}
}
}