3 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
2 changed files with 34 additions and 27 deletions

View File

@ -1,4 +1,4 @@
IMAGE_TAG=latest IMAGE_TAG=latest
CONTAINER_NAME=comprofix CONTAINER_NAME=comprofix
HUGO_BASEURL=https://comprofix.com HUGO_BASEURL=https://comprofix.com
HOSTNAME=comprofix.com HOSTNAME=comprofix.com

View File

@ -7,7 +7,9 @@ on:
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
@ -39,33 +41,38 @@ jobs:
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
"