-
Notifications
You must be signed in to change notification settings - Fork 1
49 lines (40 loc) · 1.4 KB
/
cd.yml
File metadata and controls
49 lines (40 loc) · 1.4 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
name: Deploy to EC2
on:
workflow_run:
workflows: ["Build and Push to Docker Hub"]
types: [completed]
workflow_dispatch:
jobs:
deploy:
runs-on: ubuntu-latest
environment: Pinhouse_env
if: >
${{
github.event_name == 'workflow_dispatch' ||
(github.event_name == 'workflow_run' && github.event.workflow_run.conclusion == 'success')
}}
steps:
- name: Deploy to EC2 via SSH
uses: appleboy/[email protected]
with:
host: ${{ secrets.EC2_HOST }}
username: ${{ secrets.EC2_USER }}
key: ${{ secrets.EC2_SSH_KEY }}
script: |
set -e
# (선택) 네트워크 체크 - Docker Hub 접근 확인
curl -I https://registry-1.docker.io/v2/ --max-time 8
# Docker Hub 로그인
echo "${{ secrets.DOCKER_ACCESS_TOKEN }}" | docker login -u "${{ secrets.DOCKER_USERNAME }}" --password-stdin
# 최신 이미지 pull
docker pull ${{ secrets.DOCKER_USERNAME }}/pinhouse:latest
# 기존 컨테이너 정리
docker rm -f pinhouse || true
# 실행
docker run -d \
--name pinhouse \
--restart unless-stopped \
-p 3000:3000 \
${{ secrets.DOCKER_USERNAME }}/pinhouse:latest
# 상태 확인(선택)
docker ps --filter "name=pinhouse"