-
Notifications
You must be signed in to change notification settings - Fork 2
115 lines (100 loc) · 4.15 KB
/
gradle-publish.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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
name: BE CI/CD with MySQL and EC2 Deploy
on:
push:
branches: [ "develop" ]
pull_request:
branches: [ "develop" ]
jobs:
backend-CI-and-Deploy:
runs-on: ubuntu-latest
services:
db:
image: mysql:8.0
env:
MYSQL_ROOT_PASSWORD: ${{ secrets.DB_PASSWORD }}
MYSQL_DATABASE: aimo
MYSQL_USER: ${{ secrets.DB_USERNAME }}
MYSQL_PASSWORD: ${{ secrets.DB_PASSWORD }}
ports:
- 3306:3306
options: --health-cmd="mysqladmin ping -h localhost" --health-interval=10s --health-timeout=5s --health-retries=10
steps:
# 소스 코드 체크아웃
- uses: actions/checkout@v4
# JDK 17 설정
- name: Set up JDK 17
uses: actions/setup-java@v4
with:
java-version: '17'
distribution: 'temurin'
# YML 파일 생성
- name: YML 파일 생성
working-directory: .
run: |
# backend 디렉토리 생성
mkdir -p backend/src/main/resources/
# application.yml 파일들 생성
echo "${{ secrets.APPLICATION_DEFAULT }}" > backend/src/main/resources/application.yml
echo "${{ secrets.APPLICATION_DEV }}" > backend/src/main/resources/application-dev.yml
echo "${{ secrets.APPLICATION_LOCAL }}" > backend/src/main/resources/application-local.yml
echo "${{ secrets.APPLICATION_PROD }}" > backend/src/main/resources/application-prod.yml
# github actions 시간대 확인
echo ===================
date
echo ===================
# Gradle 실행 권한 설정
- name: Grant execute permission to gradlew
run: chmod +x gradlew
working-directory: ${{ secrets.WORKING_DIRECTORY }}
# Gradle 빌드 및 테스트 실행 (로컬 컨테이너의 MySQL 사용)
- name: Build and Test with Gradle
run: ./gradlew clean build -Dspring.profiles.active=dev
working-directory: ${{ secrets.WORKING_DIRECTORY }}
env:
SPRING_DATASOURCE_URL: jdbc:mysql://aimodbfordev.cbimeayem48r.ap-northeast-2.rds.amazonaws.com:3306/aimo
SPRING_DATASOURCE_USERNAME: admin
SPRING_DATASOURCE_PASSWORD: ${{ secrets.DB_PASSWORD }}
# 빌드된 JAR 파일을 EC2로 복사
- name: Copy JAR file to EC2
uses: appleboy/scp-action@master
with:
host: ${{ secrets.EC2_HOST_DEV }}
username: ${{ secrets.EC2_USER }}
key: ${{ secrets.EC2_SSH_KEY }}
debug: true
source: ${{ secrets.WORKING_DIRECTORY }}/build/libs/*.jar
target: /home/ubuntu/
# CloudWatch 설정 파일을 EC2로 복사
- name: Copy CloudWatch config to EC2
uses: appleboy/scp-action@master
with:
host: ${{ secrets.EC2_HOST_DEV }}
username: ${{ secrets.EC2_USER }}
key: ${{ secrets.EC2_SSH_KEY }}
source: cloudwatch-config.json
target: /home/ubuntu/
# EC2 연결 테스트 추가 (debug 옵션 활성화)
- name: Test EC2 SSH Connection
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.EC2_HOST_DEV }}
username: ${{ secrets.EC2_USER }}
key: ${{ secrets.EC2_SSH_KEY }}
debug: true
script: |
echo "SSH 연결 테스트 성공"
# EC2에서 애플리케이션 실행 (screen 세션 사용)
- name: Deploy to EC2
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.EC2_HOST_DEV }}
username: ${{ secrets.EC2_USER }}
key: ${{ secrets.EC2_SSH_KEY }}
debug: true
script: |
# CloudWatch 에이전트를 설정 파일로 시작
sudo amazon-cloudwatch-agent-ctl -a fetch-config -m ec2 -c file:/home/ubuntu/cloudwatch-config.json -s
# 기존 screen 세션이 있다면 종료
if screen -list | grep -q "\bbe\b"; then screen -S be -X quit; fi
# 새로운 screen 세션으로 애플리케이션 실행
screen -dmS be java -jar /home/ubuntu/backend/build/libs/backend-server.jar --spring.profiles.active=dev