- 아키텍처
- 코드 설명
local
에서 add, commit, push
진행
push
를 하게 되면 github actions
에서 ci.yml, cd.yml 실행
ci.yml
에선 먼저 runner에서 ci/cd 하려는 레포에 접근
npm ci
를 통해 의존성 설치
후 npm run build
를 통해 build 파일 생성
cd.yml
에서도 똑같이 레포 접근, 의존성 설치, build
aws-actions/configure-aws-credentials@v1
를 통해 aws에 접속할 사용자 등록
자격 증명이 끝나면 S3, CloudFront에 배포 완료
name: CI
on:
push:
branches: ["main"]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Install dependencies
run: npm ci
- name: build
run: npm run build
main branch
에서 push 이벤트가 발생
할 때 trigger
된다는 뜻ubuntu 환경에서 실행
내 레포를 clone 및 checkout
npm ci, npm run build
를 통해 의존성 설치 및 빌드 파일 생성
name: CD
on:
push:
branches: ["main"]
jobs:
build:
runs-on: ubuntu-latest
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- uses: actions/checkout@v3
- name: Install dependencies
run: npm ci
- name: build
run: npm run build
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v1
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: ap-northeast-2
- name: Deploy to S3
run: aws s3 sync ./build s3://${{ secrets.DEV_AWS_S3_BUCKET }} --delete
- name: Invalidate CloudFront Cache
run: aws cloudfront create-invalidation --distribution-id ${{secrets.DEV_AWS_DISTRIBUTION_ID}} --paths "/*"
aws-actions/configure-aws-credentials@v1
- aws에 접속할 사용자를 등록
${{secrets.~}}로 되어있는 것
은 settings -> secrets -> actions -> new repository secret
에서 생성access-key-id, secret-access-key
는 aws iam에서 permission 추가
해줘야 함iam -> 기존 정책 직접 연결 -> AmazonS3FullAccess, CloudFrontFullAcess
체크 후 생성run: aws s3 sync ./build s3://${{ secrets.DEV_AWS_S3_BUCKET }} --delete
빌드 파일
을 s3의 버킷에 동기화
시키겠다는 의미 -> 배포
./build
는 현재 프로젝트의 빌드 파일 경로
를 의미delete 옵션
을 통해 신규 번들링에 생성되지 않은 파일이 S3에서 삭제
됨AWS_ACCESS_KEY_ID
: 배포를 위해 이번에 생성한 IAM 유저의 Access key IDAWS_REGION
: S3의 regionAWS_SECRET_ACCESS_KEY
: 배포를 위해 이번에 생성한 IAM 유저의 Secret access keyDEV_AWS_DISTRIBUTION_ID
: CloudFront Distribution IdDEV_AWS_S3_BUCKET
: S3 버킷 이름https://blog.doitreviews.com/development/2021-08-13-react-automatic-deploy/