50 lines
1.6 KiB
YAML
50 lines
1.6 KiB
YAML
# Deploy honey-be to VPS on push to main.
|
|
# Required secret: DEPLOY_SSH_PRIVATE_KEY.
|
|
# Optional: DEPLOY_VPS_HOST (default 188.116.23.7), DEPLOY_VPS_USER (default root).
|
|
name: Deploy to VPS
|
|
on:
|
|
push:
|
|
branches: [main]
|
|
|
|
jobs:
|
|
deploy:
|
|
runs-on: ubuntu-latest
|
|
env:
|
|
VPS_HOST: ${{ secrets.DEPLOY_VPS_HOST }}
|
|
VPS_USER: ${{ secrets.DEPLOY_VPS_USER }}
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Install SSH and Rsync
|
|
run: |
|
|
apt-get update -qq
|
|
apt-get install -y -qq openssh-client rsync
|
|
|
|
- name: Setup SSH
|
|
env:
|
|
SSH_HOST: ${{ secrets.DEPLOY_VPS_HOST }}
|
|
run: |
|
|
mkdir -p ~/.ssh
|
|
echo "${{ secrets.DEPLOY_SSH_PRIVATE_KEY }}" > ~/.ssh/deploy_key
|
|
chmod 600 ~/.ssh/deploy_key
|
|
eval "$(ssh-agent -s)"
|
|
ssh-add ~/.ssh/deploy_key
|
|
HOST="${SSH_HOST:-188.116.23.7}"
|
|
ssh-keyscan -H "$HOST" >> ~/.ssh/known_hosts 2>/dev/null || true
|
|
|
|
- name: Sync code to VPS
|
|
run: |
|
|
HOST="${VPS_HOST:-188.116.23.7}"
|
|
USER="${VPS_USER:-root}"
|
|
rsync -avz --delete -e "ssh -i ~/.ssh/deploy_key -o StrictHostKeyChecking=accept-new" \
|
|
--exclude '.git' \
|
|
--exclude 'target' \
|
|
./ "$USER@$HOST:/opt/app/backend/honey-be/"
|
|
|
|
- name: Run rolling update on VPS
|
|
run: |
|
|
HOST="${VPS_HOST:-188.116.23.7}"
|
|
USER="${VPS_USER:-root}"
|
|
ssh -i ~/.ssh/deploy_key "$USER@$HOST" "cd /opt/app/backend/honey-be && chmod +x scripts/rolling-update.staged.sh && sudo ./scripts/rolling-update.staged.sh"
|