This commit is contained in:
2026-01-21 12:17:44 +01:00
parent 77e63ea288
commit cdd5e38217

View File

@@ -36,17 +36,19 @@ jobs:
# --- Build image ---
- name: Build image
run: |
echo "Starting Docker build"
docker build \
--pull \
--build-arg NEXT_PUBLIC_UMAMI_WEBSITE_ID=${{ secrets.NEXT_PUBLIC_UMAMI_WEBSITE_ID }} \
--build-arg NEXT_PUBLIC_UMAMI_SCRIPT_URL=${{ secrets.NEXT_PUBLIC_UMAMI_SCRIPT_URL }} \
--build-arg NEXT_PUBLIC_SENTRY_DSN=${{ secrets.SENTRY_DSN }} \
-t registry.infra.mintel.me/mintel/mb-grid-solutions.com:latest .
echo "Docker build completed"
docker images registry.infra.mintel.me/mintel/mb-grid-solutions.com:latest --format "Built image ID: {{.ID}}"
# --- Push image ---
- name: Push image
run: |
echo "Starting Docker push"
docker push registry.infra.mintel.me/mintel/mb-grid-solutions.com:latest
echo "Docker push completed"
# --- SSH setup ---
- name: Setup SSH
@@ -59,9 +61,11 @@ jobs:
# --- Sync files ---
- name: Sync files to server
run: |
echo "Starting file sync to server"
tar czf - docker-compose.yaml | \
ssh -i ~/.ssh/id_ed25519 -o StrictHostKeyChecking=no -o IPQoS=0x00 deploy@alpha.mintel.me \
"mkdir -p /home/deploy/sites/mb-grid-solutions.com/ && tar xzf - -C /home/deploy/sites/mb-grid-solutions.com/"
"mkdir -p /home/deploy/sites/mb-grid-solutions.com/ && tar xzf - -C /home/deploy/sites/mb-grid-solutions.com/ && echo 'Files synced' && ls -la /home/deploy/sites/mb-grid-solutions.com/"
echo "File sync completed"
# --- Deploy ---
- name: Deploy on server
@@ -70,32 +74,34 @@ jobs:
REGISTRY_PASS: ${{ secrets.REGISTRY_PASS }}
run: |
ssh -i ~/.ssh/id_ed25519 -o StrictHostKeyChecking=no -o IPQoS=0x00 deploy@alpha.mintel.me "
set -e
set -ex
echo 'Logging in to registry on server...'
echo '$REGISTRY_PASS' | docker login registry.infra.mintel.me -u '$REGISTRY_USER' --password-stdin
cd /home/deploy/sites/mb-grid-solutions.com
echo 'Creating .env if needed...'
echo 'SENTRY_DSN=${{ secrets.SENTRY_DSN }}' > .env
echo 'SMTP_HOST=${{ secrets.SMTP_HOST }}' >> .env
echo 'SMTP_PORT=${{ secrets.SMTP_PORT }}' >> .env
echo 'SMTP_USER=${{ secrets.SMTP_USER }}' >> .env
echo 'SMTP_PASS=${{ secrets.SMTP_PASS }}' >> .env
echo 'SMTP_FROM=${{ secrets.SMTP_FROM }}' >> .env
echo 'CONTACT_RECIPIENT=${{ secrets.CONTACT_RECIPIENT }}' >> .env
echo 'Creating .env...'
cat > .env << EOF
SENTRY_DSN=${{ secrets.SENTRY_DSN }}
SMTP_HOST=${{ secrets.SMTP_HOST }}
SMTP_PORT=${{ secrets.SMTP_PORT }}
SMTP_USER=${{ secrets.SMTP_USER }}
SMTP_PASS=${{ secrets.SMTP_PASS }}
SMTP_FROM=${{ secrets.SMTP_FROM }}
CONTACT_RECIPIENT=${{ secrets.CONTACT_RECIPIENT }}
EOF
echo 'Pulling latest image...'
docker compose pull || echo 'Pull failed - continuing anyway...'
docker compose pull || echo 'Pull failed - continuing...'
echo 'Force recreating and restarting app container...'
docker compose up -d --force-recreate --no-deps app # ← HIER DER FIX
docker compose up -d --force-recreate --no-deps app
echo 'Pruning old images (keep last 24h)...'
echo 'Pruning old images...'
docker image prune -f --filter 'until=24h'
echo 'Deployment finished. Checking status...'
echo 'Deployment finished. Status & logs:'
docker compose ps app
docker compose logs --tail=20 app
docker compose logs --tail=30 app
"