Github Action을 이용한 React S3배포

김동언·2024년 6월 4일
0

Github Action을 활용 React 빌드 배포

React Root 폴더에 .github/workflows폴더를 생성 후 main.yml을 만들어 준다.

.github/workflows/main.yaml 폴더
name: Main CI

on:
  push:
    branches:
      - master

jobs:
  build:
    name: build-and-deploy
    runs-on: ubuntu-latest

    steps:
      - name: git clone
        uses: actions/checkout@v3

      #노드 버전 설정
      - name: Set up Node.js
        uses: actions/setup-node@v3
        with:
          node-version: '18.17.1'

      # 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 CI to false
        run: |
          echo "CI=false" >> $GITHUB_ENV

      - name: npm install
        run: npm ci

        
      # .env에 있던 환경변수들을 등록해주는 단계
      - name: .env setting
        run: |
          echo "REACT_APP_GOOGLE_ID=${{ secrets.REACT_APP_GOOGLE_ID }}" >> .env
          echo "REACT_APP_SERVER_URI=${{ secrets.REACT_APP_SERVER_URI }}" >> .env

      - name: npm build
        run: npm run build
        env:
          GENERATE_SOURCEMAP: false

      - 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_KEY_ID }}
          aws-region: ap-northeast-2

      - name: Upload to S3
        env:
          BUCKET_NAME: ${{ secrets.S3_BUCKET_NAME}}
        run: |
          aws s3 sync ./build s3://$BUCKET_NAME

secrets 설정 방법

위와 같이 변수 저장 후

 ${{ secrets.S3_BUCKET_NAME}}

이와 같이 사용하면 된다.

profile
코딩을 즐겨보자

0개의 댓글