-
Notifications
You must be signed in to change notification settings - Fork 3
78 lines (66 loc) · 2.41 KB
/
deploy.yml
File metadata and controls
78 lines (66 loc) · 2.41 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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
name: CI/CD Deploy to EC2 (Docker Hub)
on:
push:
branches: ["develop"]
permissions:
contents: read
# 전역 환경변수
env:
# Docker Hub 이미지 이름
DOCKERHUB_IMAGE: docker.io/${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKERHUB_REPO }}
# EC2에서 docker-compose.yml, .env 등이 있는 경로
APP_DIR: /home/ubuntu/travlocks
jobs:
# 1) 빌드 + Docker Hub 푸시
build-and-push:
runs-on: ubuntu-latest
steps:
# 1. 레포 체크아웃
- name: Checkout repository
uses: actions/checkout@v4
# 2. Docker 빌드 기능(buildx) 준비
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
# 3. Docker Hub 로그인 (private repo push를 위해 필요)
- name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
# 4. Docker 이미지 빌드 후 푸시
# - latest: 항상 최신 배포 이미지
# - github.sha: 특정 커밋 버전 추적/롤백용
- name: Build and Push Docker image
uses: docker/build-push-action@v6
with:
context: .
file: Dockerfile
push: true
tags: |
${{ env.DOCKERHUB_IMAGE }}:latest
${{ env.DOCKERHUB_IMAGE }}:${{ github.sha }}
# 2) EC2로 배포 (이미지 pull + compose 재기동)
deploy:
needs: build-and-push
runs-on: ubuntu-latest
steps:
# 5. EC2에 SSH 접속해서 배포 수행
- name: Deploy to EC2 via SSH
uses: appleboy/ssh-action@v1.0.3
with:
host: ${{ secrets.SSH_HOST }}
username: ${{ secrets.SSH_USER }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
script: |
set -e
echo "====== EC2 Deploy Start ======"
cd ${{ env.APP_DIR }}
echo "${{ secrets.DOCKERHUB_TOKEN }}" | docker login -u "${{ secrets.DOCKERHUB_USERNAME }}" --password-stdin
# 1) 태그를 SHA로 고정 (롤백 쉬움)
sed -i 's/^IMAGE_TAG=.*/IMAGE_TAG=${{ github.sha }}/' .env
# 2) pull + 재기동
docker-compose pull
docker-compose down || true
docker-compose up -d
docker image prune -f
echo "====== EC2 Deploy Done ======"