-
Notifications
You must be signed in to change notification settings - Fork 0
51 lines (40 loc) · 1.38 KB
/
docker-build.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
name: Build and Push Docker Image
on:
push:
branches:
- main
env:
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }}
EC2_HOST: ${{ secrets.EC2_HOST }}
EC2_KEY: ${{ secrets.EC2_KEY }}
jobs:
deploy-backend:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Debug environment variables
run: |
echo "DOCKER_USERNAME=${DOCKER_USERNAME}"
echo "DOCKER_PASSWORD=${DOCKER_PASSWORD}"
echo "EC2_HOST=${EC2_HOST}"
echo "EC2_KEY=${EC2_KEY}"
- name: Decode and save EC2 private key
run: |
echo "${{ secrets.EC2_KEY }}" | base64 --decode > ec2-private-key.pem
chmod 600 ec2-private-key.pem
- name: SSH into EC2 instance and deploy
run: |
ssh -o StrictHostKeyChecking=no -i ./ec2-private-key.pem ec2-user@${EC2_HOST} << 'EOF'
cd /home/ec2-user/fastapi-todos
# Pull latest code
git pull origin main
# Build Docker image
sudo docker build -t fastapi-to-dos .
# Stop and remove all Docker containers
sudo docker stop $(sudo docker ps -aq) || true
sudo docker rm $(sudo docker ps -aq) || true
# Run new Docker container
sudo docker run -d -p 8000:8000 fastapi-to-dos
EOF