Skip to content

feat: S3, 클라우드프론트로 배포 이전 #3

feat: S3, 클라우드프론트로 배포 이전

feat: S3, 클라우드프론트로 배포 이전 #3

Workflow file for this run

name: Admin Deploy
on:
pull_request:
branches:
- main
jobs:
build-and-deploy:
runs-on: ubuntu-latest
timeout-minutes: 10
permissions:
checks: write
pull-requests: write
steps:
- name: Repository 체크아웃
uses: actions/checkout@v3
- name: Node 설정
uses: actions/setup-node@v3
with:
node-version: '18.16.1'
- name: node_modules 캐싱
id: cache
uses: actions/cache@v3
with:
path: '**/node_modules'
key: ${{ runner.os }}-node-${{ hashFiles('**/yarn.lock') }}
restore-keys: |
${{ runner.os }}-node-
- name: 의존성 설치
if: steps.cache.outputs.cache-hit != 'true'
run: yarn install --pure-lockfile
- name: .env 파일 생성
run: |
echo "VITE_API_BASE_URL=${{ secrets.API_BASE_URL }}" > .env
- name: 클라이언트 빌드
run: yarn build
- name: AWS CLI 설정
uses: aws-actions/configure-aws-credentials@v1
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: ap-northeast-2
- name: S3 이전 파일 삭제
run: |
aws s3 rm ${{ secrets.AWS_S3_URL }} --recursive
- name: S3에 배포
run: |
aws s3 sync ./dist ${{ secrets.AWS_S3_URL }}