Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
6cb3699016 | |||
2734dd8c58 | |||
f191fe9e4a | |||
cc46db0cb3 |
@ -3,7 +3,7 @@ name: Build and Deploy Production
|
|||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
tags:
|
tags:
|
||||||
- "v*.*.*"
|
- "v*"
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-and-push:
|
build-and-push:
|
||||||
@ -41,38 +41,36 @@ jobs:
|
|||||||
HUGO_BASEURL=https://comprofix.com/
|
HUGO_BASEURL=https://comprofix.com/
|
||||||
|
|
||||||
deploy:
|
deploy:
|
||||||
runs-on: ubuntu-latest
|
runs-on: homelab-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:
|
VERSION: ${{ github.ref_name }} # <-- get the tag that triggered this workflow
|
||||||
- uses: actions/checkout@v4
|
steps:
|
||||||
|
- 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 "Host *" > ~/.ssh/config
|
||||||
echo "StrictHostKeyChecking no" >> ~/.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
|
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
|
||||||
# Extract Git tag that triggered the workflow
|
# Replace IMAGE_TAG with the version from CI
|
||||||
VERSION=\${GITHUB_REF#refs/tags/}
|
sed -i 's/^IMAGE_TAG=.*/IMAGE_TAG=${VERSION}/' .env.production
|
||||||
|
|
||||||
# Update IMAGE_TAG in .env.production
|
# Stop old container, pull new image, start container
|
||||||
sed -i 's/^IMAGE_TAG=.*/IMAGE_TAG=\$VERSION/' .env.production
|
docker compose --env-file .env.production down --remove-orphans
|
||||||
|
docker compose --env-file .env.production pull
|
||||||
# Stop old container, pull new image, start container
|
docker compose --env-file .env.production up -d
|
||||||
docker compose --env-file .env.production down --remove-orphans
|
"
|
||||||
docker compose --env-file .env.production pull
|
|
||||||
docker compose --env-file .env.production up -d
|
|
||||||
"
|
|
||||||
|
Reference in New Issue
Block a user