-
Notifications
You must be signed in to change notification settings - Fork 0
102 lines (85 loc) · 3.56 KB
/
dev-deploy.yml
File metadata and controls
102 lines (85 loc) · 3.56 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
# workflow의 이름
name: Deploy to Amazon EC2 / Spring Boot with Maven
# 환경 변수 $변수명으로 사용
env:
PROJECT_NAME: chatty-api
BUCKET_NAME: chatty-dev-s3
CODE_DEPLOY_APP: chatty-dev-codedeploy-app
CODE_DEPLOY_DEPLOYMENT_GROUP: chatty-dev-codedeploy-deployment-group
on:
push:
branches: [develop]
jobs:
build:
name: CI/CD
# 해당 jobs에서 아래의 steps들이 어떠한 환경에서 실행될 것인지를 지정합니다.
runs-on: ubuntu-latest
services:
redis:
image: redis
ports:
- 6379:6379
steps:
# 작업에서 액세스할 수 있도록 $GITHUB_WORKSPACE에서 저장소를 체크아웃합니다.
- uses: actions/checkout@v2
# Spring 구동을 위한 JDK 17을 세팅합니다.
- name: Set up JDK 17
uses: actions/setup-java@v2
with:
java-version: '17'
distribution: 'zulu'
# private repository에서 application.yml 을 가져옵니다.
- name: Bring ignored files
uses: actions/checkout@v3
with:
repository: chatty-lab/Chatty-Backend-ignored
path: temp
token: ${{ secrets.ACTION_TOKEN }}
# 필요한 application.yml을 불러와요.
- name: Move Test Config File
run: mv temp/application.yml src/main/resources/application.yml
# 필요한 application.yml을 불러와요.
- name: Move Test Config File
run: mv temp/application-test.yml src/test/resources/application.yml
- name: Move Firebase Config File
run: mv temp/chatty-lab-firebase-adminsdk-wxe5z-fa16ef3d12.json src/main/resources/chatty-lab-firebase-adminsdk-wxe5z-fa16ef3d12.json
- name: Grant execute permission for gradlew
run: chmod +x gradlew # gradlew를 실행할 수 있는 권한을 추가(리눅스의 명령어)
# 빌드 캐시를 불러옵니다.
- name: Gradle Caching
uses: actions/cache@v3
with:
path: |
~/.gradle/caches
~/.gradle/wrapper
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
restore-keys: |
${{ runner.os }}-gradle-
# main, develop 브랜치일 경우 빌드 캐시를 사용하여 빌드합니다.
- name: Setup Gradle
uses: gradle/gradle-build-action@v2.4.2
with:
arguments: build
cache-read-only: ${{ github.ref != 'refs/heads/main' && github.ref != 'refs/heads/develop' }}
# build한 후 프로젝트를 압축해요
- name: Make zip file
run: zip -r ./$PROJECT_NAME.zip .
shell: bash
# aws 인증서비스
# github repository에서 Setting에서 사용할 암호화된 변수
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v4
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: ${{ secrets.AWS_REGION}}
# Upload to S3 stroage
- name: Upload to S3
run: aws s3 cp $PROJECT_NAME.zip s3://$BUCKET_NAME/deploy/$PROJECT_NAME.zip --region ap-northeast-2
# CodeDeploy에게 배포 명령을 내려요.
- name: Code Deploy
run: >
aws deploy create-deployment --application-name $CODE_DEPLOY_APP
--deployment-config-name CodeDeployDefault.AllAtOnce
--deployment-group-name $CODE_DEPLOY_DEPLOYMENT_GROUP
--s3-location bucket=$BUCKET_NAME,bundleType=zip,key=deploy/$PROJECT_NAME.zip