This commit is contained in:
@@ -1,36 +1,63 @@
|
||||
version: '3.8'
|
||||
|
||||
services:
|
||||
mc-panel:
|
||||
mcpanel:
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile
|
||||
container_name: mc-panel
|
||||
restart: unless-stopped
|
||||
expose:
|
||||
- "8000"
|
||||
ports:
|
||||
- "8000:8000"
|
||||
environment:
|
||||
- ZITADEL_ISSUER=${ZITADEL_ISSUER}
|
||||
- ZITADEL_CLIENT_ID=${ZITADEL_CLIENT_ID}
|
||||
- ZITADEL_CLIENT_SECRET=${ZITADEL_CLIENT_SECRET}
|
||||
- BASE_URL=${BASE_URL:-http://localhost}
|
||||
- FRONTEND_URL=${FRONTEND_URL:-http://localhost}
|
||||
- SECRET_KEY=${SECRET_KEY:-change-this-in-production}
|
||||
- PYTHONUNBUFFERED=1
|
||||
# Основные настройки
|
||||
- PORT=8000
|
||||
- BASE_URL=http://localhost:8000
|
||||
- FRONTEND_URL=http://localhost:8000
|
||||
|
||||
# Безопасность (ОБЯЗАТЕЛЬНО измените в продакшене!)
|
||||
- SECRET_KEY=your-very-long-random-secret-key-change-this-in-production
|
||||
|
||||
# OIDC настройки (раскомментируйте и настройте при необходимости)
|
||||
# - ZITADEL_ISSUER=https://your-instance.zitadel.cloud
|
||||
# - ZITADEL_CLIENT_ID=your_client_id_here
|
||||
# - ZITADEL_CLIENT_SECRET=your_client_secret_here
|
||||
|
||||
# Логирование
|
||||
- LOG_LEVEL=INFO
|
||||
|
||||
volumes:
|
||||
- ./data/servers:/app/backend/servers
|
||||
- ./data/users.json:/app/backend/users.json
|
||||
- ./data/tickets.json:/app/backend/tickets.json
|
||||
- ./data:/app/data
|
||||
# Персистентные данные
|
||||
- mcpanel_servers:/app/backend/servers
|
||||
- mcpanel_data:/app/backend/data
|
||||
- mcpanel_logs:/app/logs
|
||||
|
||||
# Конфигурационные файлы (опционально)
|
||||
- ./backend/users.json:/app/backend/users.json
|
||||
- ./backend/tickets.json:/app/backend/tickets.json
|
||||
|
||||
networks:
|
||||
- mc-panel-network
|
||||
- mcpanel-network
|
||||
|
||||
# Ограничения ресурсов
|
||||
deploy:
|
||||
resources:
|
||||
limits:
|
||||
memory: 1G
|
||||
cpus: '0.5'
|
||||
reservations:
|
||||
memory: 512M
|
||||
cpus: '0.25'
|
||||
|
||||
# Health check
|
||||
healthcheck:
|
||||
test: ["CMD", "curl", "-f", "http://localhost:8000/api/auth/oidc/providers"]
|
||||
interval: 30s
|
||||
timeout: 10s
|
||||
retries: 3
|
||||
start_period: 40s
|
||||
start_period: 60s
|
||||
|
||||
# Nginx reverse proxy (опционально)
|
||||
nginx:
|
||||
image: nginx:alpine
|
||||
container_name: mc-panel-nginx
|
||||
@@ -39,31 +66,23 @@ services:
|
||||
- "80:80"
|
||||
- "443:443"
|
||||
volumes:
|
||||
- ./nginx/default.conf:/etc/nginx/nginx.conf:ro
|
||||
- frontend-static:/usr/share/nginx/html:ro
|
||||
- ./nginx/nginx.conf:/etc/nginx/nginx.conf:ro
|
||||
- ./nginx/ssl:/etc/nginx/ssl:ro
|
||||
depends_on:
|
||||
- frontend-init
|
||||
- mc-panel
|
||||
- mcpanel
|
||||
networks:
|
||||
- mc-panel-network
|
||||
|
||||
frontend-init:
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile
|
||||
container_name: mc-panel-frontend-init
|
||||
volumes:
|
||||
- frontend-static:/tmp/frontend
|
||||
command: sh -c "cp -r /app/frontend/dist/* /tmp/frontend/ 2>/dev/null || echo 'No files to copy'; echo 'Frontend initialization complete'"
|
||||
restart: "no"
|
||||
networks:
|
||||
- mc-panel-network
|
||||
|
||||
networks:
|
||||
mc-panel-network:
|
||||
driver: bridge
|
||||
- mcpanel-network
|
||||
profiles:
|
||||
- with-nginx
|
||||
|
||||
volumes:
|
||||
frontend-static:
|
||||
driver: local
|
||||
mcpanel_servers:
|
||||
driver: local
|
||||
mcpanel_data:
|
||||
driver: local
|
||||
mcpanel_logs:
|
||||
driver: local
|
||||
|
||||
networks:
|
||||
mcpanel-network:
|
||||
driver: bridge
|
||||
Reference in New Issue
Block a user