-
Notifications
You must be signed in to change notification settings - Fork 1
79 lines (67 loc) ยท 3.27 KB
/
front-build.yaml
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
name: Front Deployment
# trigger๊ฐ ๋๊ธธ ๋ฐ๋ผ๋ action์ ์
๋ ฅํฉ๋๋ค. push / pull_request๊ฐ ์์ต๋๋ค.
# ์ ๋ develop ๋ธ๋์น์ push๊ฐ ๋๋ฉด actions์ ์คํํ๋๋ก ์ค์ ํ์ต๋๋ค.
on:
push:
branches:
- develop
# ์์ ์ด๋ฒคํธ๊ฐ ํธ๋ฆฌ๊ฑฐ๋๋ฉด ์คํํ ๋ชฉ๋ก์
๋๋ค.
jobs:
build:
name: react build & deploy
# runner๊ฐ ์คํ๋ ํ๊ฒฝ์ ์ง์ ํฉ๋๋ค.
runs-on: ubuntu-latest
# name์ ๋จ๊ณ๋ณ๋ก ์คํ๋๋ ์ก์
๋ค์ ์ค๋ช
์ ๋ด์ ๊ฒ์ผ๋ก, ๋์ค์ github action์์ workflow์ ํ์๋ฉ๋๋ค.
# uses ํค์๋๋ก Action์ ๋ถ๋ฌ์ฌ ์ ์์ต๋๋ค.
steps:
# ๋ ํฌ์งํ ๋ฆฌ์ ์ ๊ทผํ์ฌ CI์๋ฒ๋ก ์ฝ๋๋ฅผ ๋ด๋ ค๋ฐ๋ ๊ณผ์ ์
๋๋ค.
- name: checkout Github Action
uses: actions/checkout@v3
# workflow๊ฐ ์คํ๋ ๋ ํ์ํ ํ์ผ ์ค์์ ๊ฑฐ์ ๋ฐ๋์ง ์๋ ํ์ผ๋ค์ GitHub์ ์บ์์ ์ฌ๋ ค๋๊ณ CI ์๋ฒ๋ก ๋ด๋ ค๋ฐ์ต๋๋ค.
# ํ๋ก์ ํธ์์ ์์ฃผ ๋ฐ๋์ง ์๋ ์๋ง์ ํจํค์ง๋ฅผ ๋งค๋ฒ ๋ค์ด๋ฐ์ ์ฌ๋ฆฌ๋ฉด ์๊ฐ๋ ์ค๋๊ฑธ๋ฆฌ๊ณ ๋คํธ์ํฌ ๋์ญํญ์ ๋ง์ด ์ฌ์ฉํ๊ฒ๋ฉ๋๋ค.
- name: Get npm cache directory
id: npm-cache-dir
run: |
echo "::set-output name=dir::$(npm config get cache)"
- uses: actions/cache@v3
id: npm-cache
with:
path: ${{ steps.npm-cache-dir.outputs.dir }}
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-node-
- name: Set up environment
run: |
echo "REACT_APP_HTTP_API_KEY=${{ secrets.REACT_APP_HTTP_API_KEY }}" >> .env
echo "REACT_APP_WS_API_KEY=${{ secrets.REACT_APP_WS_API_KEY }}" >> .env
echo "REACT_APP_REST_API_KEY=${{ secrets.REACT_APP_REST_API_KEY }}" >> .env
echo "REACT_APP_REDIRECT_URL=${{ secrets.REACT_APP_REDIRECT_URL }}" >> .env
cat .env
pwd
ls -al
- name: install npm dependencies
run: npm install
- name: react build
run: npm run build
# aws์ ์ ๊ทผํ๊ธฐ ์ํ ๊ถํ์ ๋ฐ์์ต๋๋ค.
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v1
with:
aws-access-key-id: ${{ secrets.AWS_S3_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_S3_SECRET_ACCESS_KEY_ID }}
aws-region: ap-northeast-2
# S3์ build ํ์ผ์ ์ฌ๋ฆฝ๋๋ค.
- name: Upload to S3
env:
BUCKET_NAME: ${{ secrets.AWS_S3_BUCKET_NAME }}
run: |
aws s3 sync \
./build s3://$BUCKET_NAME
# cloudfront๋ก ๋ฐฐํฌ๋๋ ํ์ผ์ ๊ธฐ๋ณธ์ค์ ์ 24์๊ฐ๋์ ์บ์๊ฐ ์ ์ง๋ฉ๋๋ค.
# ๋ฐฐํฌ ํ S3์๋ ์ต์ ์ ์ ๋ฆฌ์์ค๊ฐ ์ฌ๋ผ๊ฐ์์ง๋ง ์ฃ์ง๋ก์ผ์ด์
์ ์ด์ ํ์ผ์ด ์ฌ๋ผ๊ฐ์๋ ์ํ๋ผ๋ ์๋ฏธ์
๋๋ค.
# ๋ฐ๋ก ๋ณํ๊ฐ ๋ฐ์๋๊ธธ ๋ฐ๋๋ค๋ฉด invalidation์ ํด์ฃผ๋ฉด ๋ฉ๋๋ค.
# ํด๋น ๋ถ๋ถ์ ๊ณผ๊ธ๋ ์ ์์ผ๋ ํ์ธ ํ ์ฌ์ฉํ์ธ์
- name: CloudFront Invalidation
env:
CLOUD_FRONT_ID: ${{ secrets.AWS_CLOUDFRONT_ID }}
run: aws cloudfront create-invalidation --distribution-id $CLOUD_FRONT_ID --paths "/*"