Refactor deployment workflows to streamline code checkout and file transfer processes
Some checks failed
Deploy Development / deploy (push) Failing after 2s

This commit is contained in:
Frank John Begornia
2025-12-12 01:36:14 +08:00
parent c72e03f282
commit a12ee2e5aa
2 changed files with 42 additions and 62 deletions

View File

@@ -12,37 +12,27 @@ jobs:
steps: steps:
- name: Checkout code - name: Checkout code
uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Build Docker Image
run: | run: |
docker build -t merchbay_admin:dev . git clone ${{ gitea.repository_url }} /workspace/repo || true
cd /workspace/repo
git fetch origin ${{ gitea.ref_name }}
git checkout ${{ gitea.ref_name }}
git pull origin ${{ gitea.ref_name }}
- name: Save Docker Image - name: Setup SSH Key
run: | run: |
docker save merchbay_admin:dev | gzip > merchbay_admin_dev.tar.gz mkdir -p ~/.ssh
echo "${{ secrets.DEPLOY_SSH_KEY }}" > ~/.ssh/deploy_key
chmod 600 ~/.ssh/deploy_key
- name: Deploy to Development Server via SSH - name: Transfer Files to Development Server
uses: appleboy/scp-action@master run: |
with: cd /workspace/repo
host: ${{ secrets.DEPLOY_HOST }} scp -o StrictHostKeyChecking=no -i ~/.ssh/deploy_key merchbay_admin_dev.tar.gz docker-compose.yml ${{ secrets.DEPLOY_USER }}@${{ secrets.DEPLOY_HOST }}:/tmp/
username: ${{ secrets.DEPLOY_USER }}
key: ${{ secrets.DEPLOY_SSH_KEY }}
port: ${{ secrets.DEPLOY_PORT || 22 }}
source: "merchbay_admin_dev.tar.gz,docker-compose.yml"
target: "/tmp/merchbay_admin_dev_deploy"
- name: Execute Development Deployment Script - name: Deploy to Development Server
uses: appleboy/ssh-action@master run: |
with: ssh -o StrictHostKeyChecking=no -i ~/.ssh/deploy_key ${{ secrets.DEPLOY_USER }}@${{ secrets.DEPLOY_HOST }} << 'ENDSSH'
host: ${{ secrets.DEPLOY_HOST }}
username: ${{ secrets.DEPLOY_USER }}
key: ${{ secrets.DEPLOY_SSH_KEY }}
port: ${{ secrets.DEPLOY_PORT || 22 }}
script: |
# Set deployment directory for dev # Set deployment directory for dev
DEPLOY_DIR="/var/www/merchbay_admin_dev" DEPLOY_DIR="/var/www/merchbay_admin_dev"
@@ -50,7 +40,7 @@ jobs:
mkdir -p $DEPLOY_DIR mkdir -p $DEPLOY_DIR
# Load the Docker image # Load the Docker image
cd /tmp/merchbay_admin_dev_deploy cd /tmp
docker load < merchbay_admin_dev.tar.gz docker load < merchbay_admin_dev.tar.gz
# Copy docker-compose.yml to deployment directory # Copy docker-compose.yml to deployment directory
@@ -100,10 +90,11 @@ jobs:
docker compose exec -T app php artisan view:cache docker compose exec -T app php artisan view:cache
# Cleanup # Cleanup
rm -rf /tmp/merchbay_admin_dev_deploy rm -f /tmp/merchbay_admin_dev.tar.gz /tmp/docker-compose.yml
echo "Development deployment completed successfully!" echo "Development deployment completed successfully!"
echo "Application available at: https://dev.merchbay.app" echo "Application available at: https://dev.merchbay.app"
ENDSSH
- name: Health Check - name: Health Check
run: | run: |

View File

@@ -15,45 +15,33 @@ jobs:
steps: steps:
- name: Checkout code - name: Checkout code
uses: actions/checkout@v3 run: |
git clone ${{ gitea.repository_url }} /workspace/repo || true
- name: Set up Docker Buildx cd /workspace/repo
uses: docker/setup-buildx-action@v2 git fetch origin ${{ gitea.ref_name }}
git checkout ${{ gitea.ref_name }}
- name: Login to Docker Registry (Optional) git pull origin ${{ gitea.ref_name }}
if: ${{ secrets.DOCKER_REGISTRY_URL != '' }}
uses: docker/login-action@v2
with:
registry: ${{ secrets.DOCKER_REGISTRY_URL }}
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Build Docker Image - name: Build Docker Image
run: | run: |
cd /workspace/repo
docker build -t merchbay_admin:latest . docker build -t merchbay_admin:latest .
- name: Save Docker Image
run: |
docker save merchbay_admin:latest | gzip > merchbay_admin.tar.gz docker save merchbay_admin:latest | gzip > merchbay_admin.tar.gz
- name: Deploy to Server via SSH - name: Setup SSH Key
uses: appleboy/scp-action@master run: |
with: mkdir -p ~/.ssh
host: ${{ secrets.DEPLOY_HOST }} echo "${{ secrets.PROD_DEPLOY_SSH_KEY }}" > ~/.ssh/deploy_key
username: ${{ secrets.DEPLOY_USER }} chmod 600 ~/.ssh/deploy_key
key: ${{ secrets.DEPLOY_SSH_KEY }}
port: ${{ secrets.DEPLOY_PORT || 22 }}
source: "merchbay_admin.tar.gz,docker-compose.yml"
target: "/tmp/merchbay_admin_deploy"
- name: Execute Production Deployment Script - name: Transfer Files to Production Server
uses: appleboy/ssh-action@master run: |
with: cd /workspace/repo
host: ${{ secrets.PROD_DEPLOY_HOST }} scp -o StrictHostKeyChecking=no -i ~/.ssh/deploy_key merchbay_admin.tar.gz docker-compose.yml ${{ secrets.PROD_DEPLOY_USER }}@${{ secrets.PROD_DEPLOY_HOST }}:/tmp/
username: ${{ secrets.PROD_DEPLOY_USER }}
key: ${{ secrets.PROD_DEPLOY_SSH_KEY }} - name: Deploy to Production Server
port: ${{ secrets.PROD_DEPLOY_PORT || 22 }} run: |
script: | ssh -o StrictHostKeyChecking=no -i ~/.ssh/deploy_key ${{ secrets.PROD_DEPLOY_USER }}@${{ secrets.PROD_DEPLOY_HOST }} << 'ENDSSH'
# Set deployment directory for production # Set deployment directory for production
DEPLOY_DIR="/var/www/merchbay_admin" DEPLOY_DIR="/var/www/merchbay_admin"
@@ -61,7 +49,7 @@ jobs:
mkdir -p $DEPLOY_DIR mkdir -p $DEPLOY_DIR
# Load the Docker image # Load the Docker image
cd /tmp/merchbay_admin_deploy cd /tmp
docker load < merchbay_admin.tar.gz docker load < merchbay_admin.tar.gz
# Copy docker-compose.yml to deployment directory # Copy docker-compose.yml to deployment directory
@@ -111,10 +99,11 @@ jobs:
docker compose exec -T app php artisan view:cache docker compose exec -T app php artisan view:cache
# Cleanup # Cleanup
rm -rf /tmp/merchbay_admin_deploy rm -f /tmp/merchbay_admin.tar.gz /tmp/docker-compose.yml
echo "Production deployment completed successfully!" echo "Production deployment completed successfully!"
echo "Application available at: https://merchbay.com" echo "Application available at: https://merchbay.com"
ENDSSH
- name: Health Check - name: Health Check
run: | run: |