#!/bin/bash # 🏭 MYP Backend - Standalone Server Start # Startet den Backend-Server vollständig unabhängig vom Frontend set -e echo "🏭 MYP Backend - Standalone Server wird gestartet..." # Farben für Terminal-Ausgabe RED='\033[0;31m' GREEN='\033[0;32m' YELLOW='\033[1;33m' BLUE='\033[0;34m' NC='\033[0m' # No Color # Funktionen log_info() { echo -e "${BLUE}[INFO]${NC} $1" } log_success() { echo -e "${GREEN}[SUCCESS]${NC} $1" } log_warning() { echo -e "${YELLOW}[WARNING]${NC} $1" } log_error() { echo -e "${RED}[ERROR]${NC} $1" } # Arbeitsverzeichnis setzen SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)" cd "$SCRIPT_DIR" log_info "Arbeitsverzeichnis: $SCRIPT_DIR" # Umgebungsvariablen laden if [ -f ".env.backend" ]; then log_info "Lade Backend-Umgebungsvariablen..." export $(cat .env.backend | grep -v '^#' | xargs) fi # Prüfe Docker-Installation if ! command -v docker &> /dev/null; then log_error "Docker ist nicht installiert!" exit 1 fi if ! command -v docker-compose &> /dev/null; then log_error "Docker Compose ist nicht installiert!" exit 1 fi log_success "Docker-Installation verifiziert" # Alte Container stoppen und entfernen log_info "Stoppe eventuell laufende Backend-Container..." docker-compose -f docker-compose.backend.yml down --remove-orphans 2>/dev/null || true # Images aufräumen (optional) if [ "$1" = "--clean" ]; then log_info "Räume alte Backend-Images auf..." docker-compose -f docker-compose.backend.yml down --rmi all --volumes 2>/dev/null || true docker system prune -f fi # Notwendige Verzeichnisse erstellen log_info "Erstelle notwendige Verzeichnisse..." mkdir -p instance logs migrations/versions config # Backend-Container builden und starten log_info "Backend-Container werden gebaut und gestartet..." docker-compose -f docker-compose.backend.yml up --build -d # Warten auf Backend-Start log_info "Warte auf Backend-Service..." timeout=120 counter=0 while [ $counter -lt $timeout ]; do if curl -f http://localhost:5000/health >/dev/null 2>&1; then log_success "Backend-Server ist bereit!" break fi if [ $((counter % 10)) -eq 0 ]; then log_info "Warte auf Backend-Service... ($counter/$timeout Sekunden)" fi sleep 1 counter=$((counter + 1)) done if [ $counter -eq $timeout ]; then log_error "Backend-Service konnte nicht gestartet werden!" log_info "Zeige Backend-Logs:" docker-compose -f docker-compose.backend.yml logs backend exit 1 fi # Migrationen ausführen log_info "Führe Datenbank-Migrationen aus..." docker-compose -f docker-compose.backend.yml exec backend flask db upgrade || log_warning "Migrationen fehlgeschlagen oder nicht erforderlich" # Service-Status anzeigen log_info "Backend-Service Status:" docker-compose -f docker-compose.backend.yml ps # URLs anzeigen echo "" log_success "🎉 Backend-Server erfolgreich gestartet!" echo "" echo "📡 Backend-API: http://localhost:5000" echo "🔧 Backend-Health: http://localhost:5000/health" echo "📋 Backend-Swagger: http://localhost:5000/swagger" echo "🗄️ PostgreSQL: localhost:5432" echo "⚡ Redis-Cache: localhost:6379" echo "" # Logs anzeigen (optional) if [ "$1" = "--logs" ] || [ "$2" = "--logs" ]; then log_info "Zeige Backend-Logs (Strg+C zum Beenden):" docker-compose -f docker-compose.backend.yml logs -f fi log_info "Verwende 'docker-compose -f docker-compose.backend.yml logs -f' um Logs zu verfolgen" log_info "Verwende 'docker-compose -f docker-compose.backend.yml down' um den Server zu stoppen"