-
Notifications
You must be signed in to change notification settings - Fork 0
57 lines (48 loc) · 1.75 KB
/
main.yml
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
55
56
57
name: Deploy Docker Compose App to Private Server
on:
push:
branches:
- develop
jobs:
deploy:
runs-on: ubuntu-latest
environment: Production
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Set up SSH
run: |
echo "${{ secrets.SSH_PRIVATE_KEY }}" > private_key.pem
chmod 600 private_key.pem
eval $(ssh-agent -s)
rm private_key.pem
- name: Test SSH connection
run: |
ssh -o StrictHostKeyChecking=no -p ${{ secrets.SSH_PORT }} ${{ secrets.SSH_USER }}@${{ secrets.SSH_HOST }} "echo 'SSH connection successful!'"
- name: Copy files to the server
run: |
mkdir /tmp/c218/
rsync -avz -e "ssh -o StrictHostKeyChecking=no -p ${{ secrets.SSH_PORT }}" \
--exclude '.git' --exclude '.github' \
./ ${{ secrets.SSH_USER }}@${{ secrets.SSH_HOST }}:/tmp/c218/
- name: Environment variables
run: |
echo "DBName=${{secrets.DBName}}" >> $GITHUB_ENV
echo "Host=${{secrets.Host}}" >> $GITHUB_ENV
echo "Password=${{secrets.Password}}" >> $GITHUB_ENV
echo "User=${{secrets.User}}" >> $GITHUB_ENV
echo "SecurityKey=${{secrets.SecurityKey}}" >> $GITHUB_ENV
- name: Build and restart Docker Compose
run: |
ssh -o StrictHostKeyChecking=no -p ${{ secrets.SSH_PORT }} ${{ secrets.SSH_USER }}@${{ secrets.SSH_HOST }} "
cd /tmp/c218/ &&
docker-compose down &&
docker-compose up -d --build &&
docker image prune -f
"
- name: Clean up application files
run: |
ssh -o StrictHostKeyChecking=no -p ${{ secrets.SSH_PORT }} ${{ secrets.SSH_USER }}@${{ secrets.SSH_HOST }} "
rm -rf /tmp/c218/*
rm /tmp/c218
"