-
Notifications
You must be signed in to change notification settings - Fork 1
54 lines (45 loc) · 1.47 KB
/
deploy.yml
File metadata and controls
54 lines (45 loc) · 1.47 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
name: Deploy to Drift
on:
push:
branches:
- main
jobs:
deploy:
name: Deploy
runs-on: ubuntu-latest
concurrency:
group: deployment_lock
cancel-in-progress: false
steps:
- name: Checkout Code
uses: actions/checkout@v4
- name: Set up SSH key
env:
PROXY_HOST: ${{ vars.PROXY_HOST }}
SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }}
run: |
mkdir -p ~/.ssh
echo "$SSH_PRIVATE_KEY" > ~/.ssh/key
chmod 600 ~/.ssh/key
ssh-keyscan -H $PROXY_HOST >> ~/.ssh/known_hosts
- name: Deploy to OpenStack server
env:
PROXY_HOST: ${{ vars.PROXY_HOST }}
HOST: ${{ vars.HOST }}
USER: ${{ vars.USER }}
WORKING_DIRECTORY: ${{ vars.WORKING_DIRECTORY }}
run: |
# Start ssh-agent and add the SSH key
eval $(ssh-agent -s)
ssh-add ~/.ssh/key
# SSH into the server via the proxy and run deployment commands
ssh -o StrictHostKeyChecking=no -J $USER@$PROXY_HOST $USER@$HOST << ENDSSH
# WE ARE NOW ON THE REMOTE SERVER
# If any command fails, the script will exit immediately with a non-zero status
set -euo pipefail
# Navigate to the working directory, pull the latest code, and run the deployment script
cd "$WORKING_DIRECTORY"
git fetch
git reset --hard origin/main
./deploy.sh
ENDSSH