diff --git a/deploy/terraform/cloud-init-app.yaml.tftpl b/deploy/terraform/cloud-init-app.yaml.tftpl index 4bd126f..798374a 100644 --- a/deploy/terraform/cloud-init-app.yaml.tftpl +++ b/deploy/terraform/cloud-init-app.yaml.tftpl @@ -54,9 +54,21 @@ write_files: # SPA bauen (Profil-/QR-Links zeigen auf die öffentliche Domain) docker run --rm -e VITE_PUBLIC_BASE="https://$DOMAIN" -v "$PWD/frontend":/app -w /app node:25-alpine sh -c "npm ci && npm run build" chown -R 1000:1000 /opt/vcard4 + # Hetzner-Privatnetz-NIC (nicht eth0) sicher per DHCP hochziehen (für DB-Zugriff). + # Manchmal kommt das private Interface beim ersten Boot nicht hoch → DB unerreichbar. + PRIV=$(ls /sys/class/net | grep -E '^(enp|ens)' | grep -v '^eth0$' | head -1 || true) + if [ -n "${PRIV:-}" ] && ! ip -4 addr show "$PRIV" | grep -q 'inet 10\.'; then + printf '[Match]\nName=%s\n[Network]\nDHCP=ipv4\n' "$PRIV" > "/etc/systemd/network/10-$PRIV.network" + ip link set "$PRIV" up || true + systemctl restart systemd-networkd || true + for i in $(seq 1 30); do ip -4 addr | grep -q 'inet 10\.' && break; sleep 2; done + fi COMPOSE="docker compose --project-directory /opt/vcard4 -f deploy/compose/docker-compose.prod.yml" $COMPOSE up -d --build sleep 20 + # PHP-Abhängigkeiten installieren: vendor/ ist gitignored und /app ist als Volume + # gemountet (überdeckt ein im Image gebautes vendor) → hier in den Container hinein. + $COMPOSE exec -T -e COMPOSER_HOME=/tmp/composer php composer install --no-dev --optimize-autoloader --no-interaction --no-scripts if [ "$RUN_MIGRATIONS" = "true" ]; then $COMPOSE exec -T php php bin/console doctrine:migrations:migrate --no-interaction || true # Erst-Befüllung (idempotent: überspringt, wenn admin@vcard4reseller.de existiert)