4 Commits

Author SHA1 Message Date
c0e2a1c1f4 chore: update for host 2025-09-06 18:53:52 +10:00
50f4258a20 chore: update for host key checking
Some checks failed
Build and Deploy Production / build-and-push (push) Successful in 2m8s
Build and Deploy Production / deploy (push) Failing after 13s
2025-09-06 18:44:06 +10:00
18b38d7cc7 chore: update for production CI/CD
Some checks failed
Build and Deploy Production / build-and-push (push) Successful in 2m9s
Build and Deploy Production / deploy (push) Failing after 10s
2025-09-06 18:39:34 +10:00
11fc74b35d chore: update for production
Some checks failed
Build and Deploy Production / deploy (push) Has been cancelled
Build and Deploy Production / build-and-push (push) Has been cancelled
2025-09-06 18:34:30 +10:00
2 changed files with 43 additions and 26 deletions

View File

@ -3,11 +3,11 @@ name: Build and Deploy Production
on: on:
push: push:
tags: tags:
- "v*" - "v*.*.*"
jobs: jobs:
build-and-push: build-and-push:
runs-on: ubuntu-latest runs-on: homelab-latest
container: container:
image: catthehacker/ubuntu:act-latest image: catthehacker/ubuntu:act-latest
env: env:
@ -24,13 +24,19 @@ jobs:
username: ${{ secrets.REGISTRY_USERNAME }} username: ${{ secrets.REGISTRY_USERNAME }}
password: ${{ secrets.REGISTRY_TOKEN }} password: ${{ secrets.REGISTRY_TOKEN }}
- name: Build and push Docker image - name: Extract version from tag
id: vars
run: echo "VERSION=${GITHUB_REF_NAME}" >> $GITHUB_ENV
- name: Build and push Docker images
uses: docker/build-push-action@v6 uses: docker/build-push-action@v6
with: with:
context: . context: .
file: ./Dockerfile file: ./Dockerfile
push: true push: true
tags: ${{ env.DOCKER_REGISTRY }}/${{ env.IMAGE_NAME }}:${{ github.ref_name }} tags: |
${{ env.DOCKER_REGISTRY }}/${{ env.IMAGE_NAME }}:latest
${{ env.DOCKER_REGISTRY }}/${{ env.IMAGE_NAME }}:${{ env.VERSION }}
build-args: | build-args: |
HUGO_BASEURL=https://comprofix.com/ HUGO_BASEURL=https://comprofix.com/
@ -49,13 +55,24 @@ jobs:
mkdir -p ~/.ssh mkdir -p ~/.ssh
eval $(ssh-agent -s) eval $(ssh-agent -s)
ssh-add <(echo "${{ secrets.SSH_PRIVATE_KEY }}") ssh-add <(echo "${{ secrets.SSH_PRIVATE_KEY }}")
echo "Host *" > ~/.ssh/config
echo "StrictHostKeyChecking no" >> ~/.ssh/config
echo "Uploading docker-compose.yml and .env.production..." echo "Uploading docker-compose.yml and .env.production..."
scp docker-compose.yml $DEPLOY_USER@$DEPLOY_HOST:$DEPLOY_PATH scp docker-compose.yml $DEPLOY_USER@$DEPLOY_HOST:$DEPLOY_PATH
scp .env.production $DEPLOY_USER@$DEPLOY_HOST:$DEPLOY_PATH/.env scp .env.production $DEPLOY_USER@$DEPLOY_HOST:$DEPLOY_PATH/.env.production
echo "Deploying production container..." echo "Deploying production container..."
ssh -o StrictHostKeyChecking=no $DEPLOY_USER@$DEPLOY_HOST " ssh -o StrictHostKeyChecking=no $DEPLOY_USER@$DEPLOY_HOST "
cd $DEPLOY_PATH cd $DEPLOY_PATH
docker compose --env-file .env up -d # Extract Git tag that triggered the workflow
VERSION=\${GITHUB_REF#refs/tags/}
# Update IMAGE_TAG in .env.production
sed -i 's/^IMAGE_TAG=.*/IMAGE_TAG=\$VERSION/' .env.production
# Stop old container, pull new image, start container
docker compose --env-file .env.production down --remove-orphans
docker compose --env-file .env.production pull
docker compose --env-file .env.production up -d
" "