-
Notifications
You must be signed in to change notification settings - Fork 2
90 lines (76 loc) · 3.4 KB
/
deploy.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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
# 워크 플로우 이름
name: Java CI with Gradle
# 워크 플로우가 언제 실행 될지를 정한다.
on:
push:
branches: [ "main" ]
pull_request:
branches: [ "main" ]
# 워크 플로우가 깃 레포에 대한 권한을 읽기 만 가능하게 설정한다.
permissions:
contents: read
# 워크플로우에서 할 작업 정의한다.
jobs:
# 작업 환경 = 우분투 최신 버전
build:
runs-on: ubuntu-latest
# 깃허브에서 제공하는 checkout 엑션 사용
steps:
- uses: actions/checkout@v3
# JDK 17 설정한당
# temurin = Adoptium에서 제공하는 JDK
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: '17'
distribution: 'temurin'
# gradle wrapper 파일에 실행 권한을 부여
# gradle wrapper = 개발자가 특정 버전의 Gradle을 미리 설치하지 않고도 Gradle 빌드를 실행할 수 있게 해주는 편리한 도구
- name: Grant execute permission for gradlew
run: chmod +x gradlew
# Gradle 빌드 엑션을 이용해서 프로젝트 빌드
- name: Build with Gradle
uses: gradle/[email protected]
with:
arguments: build
- name: Create Docker Images
run : |
docker login -u ${{ secrets.DOCKER_USERNAME }} -p ${{ secrets.DOCKER_PASSWORD }}
docker build -t ${{ secrets.DOCKER_USERNAME }}/mada-project .
docker push ${{ secrets.DOCKER_USERNAME }}/mada-project
# 빌드해서 생긴 JAR 파일을 깃허브 아티팩트로 업로드!!
#- name: Upload build artifact
# uses: actions/upload-artifact@v4
# with:
# name: trelloServer
# path: build/libs/trelloServer-0.0.1-SNAPSHOT.jar
# 배포 **
deploy:
needs: build
runs-on: ubuntu-latest
# 위의 빌드작업한 JAR 파일 = 아티팩트를 다운로드
steps:
- name: Download Docker Container
uses: appleboy/ssh-action@master
id: deploy-prod
with:
host: ${{ secrets.EC2_HOST }}
username: ${{ secrets.EC2_USERNAME }}
key: ${{ secrets.EC2_SSH_KEY }}
script: |
sudo docker ps
sudo docker pull ${{ secrets.DOCKER_USERNAME }}/mada-project
sudo docker run -d -p 8080:8080 ${{ secrets.DOCKER_USERNAME }}/mada-project
sudo docker image prune -f
# EC2에 배포
# EC2 SSH 키를 private_key.pem 파일로 저장 ( 위치는 GitHub 서버 )
# SCP를 사용하여 JAR 파일을 EC2 서버로 복사
# SSH를 사용하여 EC2 서버에 연결하고 현재 실행 중인 Java 프로세스를 종료한 다음 새로운 Java 프로세스 생성 및 실행!!
## NLP 적용하면 IP -> 도메인으로 수정 + EC2 늘리면 run 추가
#- name: Deploy to EC2
# run: |
# echo "${{ secrets.EC2_SSH_KEY }}" > private_key.pem
# chmod 600 private_key.pem
# scp -i private_key.pem -o StrictHostKeyChecking=no build/libs/trelloServer-0.0.1-SNAPSHOT.jar ${{ secrets.EC2_USERNAME }}@${{ secrets.EC2_HOST }}:/home/${{ secrets.EC2_USERNAME }}/trelloServer.jar
# ssh -i private_key.pem -o StrictHostKeyChecking=no ${{ secrets.EC2_USERNAME }}@${{ secrets.EC2_HOST }} "pgrep java | xargs kill -9; nohup java -jar /home/${{ secrets.EC2_USERNAME }}/trelloServer.jar > app.log 2>&1 &"
# rm -f private_key.pem