4 Commits

Author SHA1 Message Date
cc46db0cb3 chore: update for production run
All checks were successful
Build and Deploy Production / build-and-push (push) Successful in 2m8s
2025-09-06 18:55:08 +10:00
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
2 changed files with 36 additions and 29 deletions

View File

@ -3,11 +3,13 @@ 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:
image: catthehacker/ubuntu:act-latest
env: env:
DOCKER_REGISTRY: git.comprofix.com DOCKER_REGISTRY: git.comprofix.com
IMAGE_NAME: mmckinnon/comprofix.com IMAGE_NAME: mmckinnon/comprofix.com
@ -38,34 +40,39 @@ jobs:
build-args: | build-args: |
HUGO_BASEURL=https://comprofix.com/ HUGO_BASEURL=https://comprofix.com/
deploy: deploy:
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: build-and-push needs: build-and-push
env: env:
DEPLOY_USER: administrator DEPLOY_USER: administrator
DEPLOY_HOST: docker.comprofix.xyz DEPLOY_HOST: docker.comprofix.xyz
DEPLOY_PATH: /opt/comprofix DEPLOY_PATH: /opt/comprofix
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
- name: Deploy to production server - name: Deploy to production server
run: | run: |
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.production
# Replace IMAGE_TAG in .env.production with the current VERSION echo "Deploying production container..."
sed "s/^IMAGE_TAG=.*/IMAGE_TAG=${{ env.VERSION }}/" .env.production > .env.production.new ssh -o StrictHostKeyChecking=no $DEPLOY_USER@$DEPLOY_HOST "
cd $DEPLOY_PATH
# Extract Git tag that triggered the workflow
VERSION=\${GITHUB_REF#refs/tags/}
scp .env.production.new $DEPLOY_USER@$DEPLOY_HOST:$DEPLOY_PATH/.env.production # Update IMAGE_TAG in .env.production
sed -i 's/^IMAGE_TAG=.*/IMAGE_TAG=\$VERSION/' .env.production
echo "Deploying production container..." # Stop old container, pull new image, start container
ssh -o StrictHostKeyChecking=no $DEPLOY_USER@$DEPLOY_HOST " docker compose --env-file .env.production down --remove-orphans
cd $DEPLOY_PATH docker compose --env-file .env.production pull
docker compose --env-file .env.production down --remove-orphans docker compose --env-file .env.production up -d
docker compose --env-file .env.production pull --ignore-pull-failures "
docker compose --env-file .env.production up -d
"