Skip to content

Update deploy-test-server.yml #10

Update deploy-test-server.yml

Update deploy-test-server.yml #10

name: Angular CI/CD
on:
push:
branches:
- master
workflow_dispatch:
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Use Node.js
uses: actions/setup-node@v4
with:
node-version: '18'
- name: Install dependencies
run: npm install
- name: Build the Angular app
run: npm run build-prod
- name: Compress dist folder
run: tar -czf dist.tar.gz dist/
- name: Upload artifact
uses: actions/[email protected]
with:
name: dist
path: dist.tar.gz
deploy:
needs: build
runs-on: ubuntu-latest
steps:
- name: Download artifact
uses: actions/download-artifact@v4
with:
name: dist
- name: Add SSH private key to the agent
env:
SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }}
run: |
mkdir -p ~/.ssh
echo "$SSH_PRIVATE_KEY" > ~/.ssh/id_rsa
chmod 600 ~/.ssh/id_rsa
ssh-keyscan -H ${{ secrets.REMOTE_HOST }} >> ~/.ssh/known_hosts
chmod 644 ~/.ssh/known_hosts
- name: Copy files to server
uses: appleboy/scp-action@master
with:
host: ${{ secrets.REMOTE_HOST }}
username: ${{ secrets.REMOTE_USER }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
port: 22
source: "dist.tar.gz"
target: "/root/"
- name: Run deployment script on server
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.REMOTE_HOST }}
username: ${{ secrets.REMOTE_USER }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
port: 22
script: |
cd /root
rm -rf dist
tar -zxvf dist.tar.gz
docker exec -it nginx rm -rf /var/www/portal > /dev/null
docker cp dist/aqua-viewer nginx:/var/www/portal > /dev/null
docker restart nginx > /dev/null