-
Notifications
You must be signed in to change notification settings - Fork 0
162 lines (132 loc) · 5.11 KB
/
backend_mail_cd.yml
File metadata and controls
162 lines (132 loc) · 5.11 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
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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
name: Backend Mail Continuous Delivery
on:
push:
paths:
- "backend/mail-service/**"
branches:
- main
workflow_dispatch:
permissions: write-all
env:
MAIL_JAR_TARGET_PATH: "backend/mail-service/build/libs/mail-service.jar"
MAIL_DOCKER_TARGET_PATH: "backend/mail-service/Dockerfile.prod"
MAIL_FOLDER_PATH: "/home/app/backend/mail-service"
jobs:
# 사전 작업
setup:
runs-on: ubuntu-22.04
outputs:
build-cache-key: ${{ steps.build-cache.outputs.key }}
current-datetime: ${{ steps.datetime.outputs.datetime }}
steps:
- uses: actions/checkout@v4
- name: Get current date and time
id: datetime
run: echo "datetime=$(date '+%Y-%m-%d_%H-%M-%S')" >> $GITHUB_OUTPUT
- name: Generate mail-service build cache key
id: build-cache
run: echo "key=$(echo build-${{ runner.os }}-gradle-${{ hashFiles('backend/mail-service/**/*.gradle*', 'backend/mail-service/**/gradle-wrapper.properties') }})" >> $GITHUB_OUTPUT
- name: docker-compose.prod.yml hash key
id: compose-hash
run: |
echo "DOCKER_KEY=$(sha256sum docker-compose.prod.yml | awk '{ print $1 }')" >> $GITHUB_ENV
# 캐시가 존재하면 파일 전송 스킵
- name: Check cache for docker-compose.prod.yml
id: cache-check
uses: actions/cache@v4
with:
path: ./docker-compose.prod.yml
key: ${{ runner.os }}-docker-compose-prod-${{ env.DOCKER_KEY }}
- name: Modify permissions
run: chmod o+rwx docker-compose.prod.yml
- name: Send docker-compose.prod.yml
if: steps.cache-check.outputs.cache-hit != 'true'
uses: appleboy/scp-action@master
with:
proxy_host: ${{ secrets.PROXY_HOST }}
proxy_username: ${{ secrets.PROXY_HOST_USERNAME }}
proxy_key: ${{ secrets.PROXY_HOST_KEY }}
host: ${{ secrets.REMOTE_HOST }}
username: ${{ secrets.REMOTE_HOST_USERNAME }}
key: ${{ secrets.REMOTE_HOST_KEY }}
source: "docker-compose.prod.yml"
target: "/home/app"
build:
needs: setup
runs-on: ubuntu-22.04
defaults:
run:
working-directory: backend/mail-service
steps:
- uses: actions/checkout@v4
- name: Gradle Caching
id: cache-gradle
uses: actions/cache@v4
with:
path: |
~/.gradle/caches
~/.gradle/wrapper
key: ${{ needs.setup.outputs.build-cache-key }}
restore-keys: |
${{ runner.os }}-gradle-
- name: Cache Check
if: steps.cache-gradle.outputs.cache-hit == 'true'
run: echo 'Gradle cache hit!'
- name: Set up JDK 17
uses: actions/setup-java@v4
with:
java-version: "17"
distribution: "temurin"
- name: Grant execute permission for gradlew
run: chmod +x gradlew
- name: Build with Gradle
run: ./gradlew build -x test
# (Actions에서 생성한 파일은 권한을 수정해야 scp로 보낼 때 오류가 안생김)
- name: Modify permissions
run: chmod o+rwx build/libs/mail-service.jar
- name: Send jar
uses: appleboy/scp-action@master
with:
proxy_host: ${{ secrets.PROXY_HOST }}
proxy_username: ${{ secrets.PROXY_HOST_USERNAME }}
proxy_key: ${{ secrets.PROXY_HOST_KEY }}
host: ${{ secrets.REMOTE_HOST }}
username: ${{ secrets.REMOTE_HOST_USERNAME }}
key: ${{ secrets.REMOTE_HOST_KEY }}
source: ${{ env.MAIL_JAR_TARGET_PATH }}
target: ${{ env.MAIL_FOLDER_PATH }}
strip_components: 4 # 파일을 복사할 때 source 경로에서 몇 개의 컴포넌트(디렉토리)를 제거할 것인지를 지정합니다. 4이므로, backend/main-service/build/libs/devlog.jar 에서 backend, main-service, build, libs가 사라짐.
- name: Modify permissions Dockerfile.prod
run: chmod o+rwx Dockerfile.prod
- name: Send Dockerfile.prod
uses: appleboy/scp-action@master
with:
proxy_host: ${{ secrets.PROXY_HOST }}
proxy_username: ${{ secrets.PROXY_HOST_USERNAME }}
proxy_key: ${{ secrets.PROXY_HOST_KEY }}
host: ${{ secrets.REMOTE_HOST }}
username: ${{ secrets.REMOTE_HOST_USERNAME }}
key: ${{ secrets.REMOTE_HOST_KEY }}
source: ${{ env.MAIL_DOCKER_TARGET_PATH }}
target: ${{ env.MAIL_FOLDER_PATH }}
strip_components: 2
startup:
needs:
- build
runs-on: ubuntu-22.04
concurrency:
group: startup-lock
cancel-in-progress: false
steps:
- name: Restart Server
uses: appleboy/ssh-action@master
with:
proxy_host: ${{ secrets.PROXY_HOST }}
proxy_username: ${{ secrets.PROXY_HOST_USERNAME }}
proxy_key: ${{ secrets.PROXY_HOST_KEY }}
host: ${{ secrets.REMOTE_HOST }}
username: ${{ secrets.REMOTE_HOST_USERNAME }}
key: ${{ secrets.REMOTE_HOST_KEY }}
script: |
cd /home/app
docker compose -f docker-compose.prod.yml up -d --build mail-service