S3+Cloudfront를 활용한 정적 웹 배포

김철준·2023년 2월 19일
14

Devops

목록 보기
5/9

이번에는 aws 서비스인 s3와 cloudfront를 활용하여 정적 웹을 배포하는 방법을 살펴보겠다.

s3와 cloudfront를 활용하여 배포

s3와 cloudfront를 활용하여 배포를 시작해보자.
나는 기존의 토이 프로젝트를 netilfy로 배포하여 발생한 이슈가 있었기때문에 해당 방법으로 배포해보려한다.

나의 프로젝트의 경우 리액트로 만든 프로젝트이다.

1. S3 버킷 생성

  • S3 버킷 생성
    우선 aws s3로 가서 버킷을 생성하자.
  • 이름 입력 및 리전 선택
    버킷 이름을 입력하고 리전을 선택해준다.

    해외 서비스를 하지않고 국내 서비스를 한다면 서울 리전으로 선택해주면 된다.

  • 객체 소유권 선택
    객체소유권의 선택란에서 권장하는 ACL 비활성화됨(권장)을 선택해준다.
    ACL 비활성화됨(권장)
    ACL 활성화됨

  • 퍼블릭 엑세스 차단 설정
    디폴트로 퍼블릭 엑세스 차단 설정을 체크가 되어있을텐데 우리는 s3로 바로 접속하는 것이 아닌 cloudfront를 통해 접속할 것이기 때문에 액세스를 차단해놔도 된다.

  • 버킷 버전 관리
    디폴트로 버킷 버전 관리가 비활성화로 되어있을텐데 그대로 둔다.
    설명에 잘 나와있듯이 버전 관리는 객체의 여러 버전을 동일한 버킷에서 관리하기 위한 수단이라한다.
    나는 해당 프로젝트를 거의 건드릴일이 없기 때문에 여러 버전으로 관리할 필요가 없다.
    그러므로 비활성화로 체크해주겠다.

  • 기본 암호화
    암호화를 활성화하면 파일들을 버킷에 업로드할 때 암호화하여 저장할 수 있다.
    하지만 나의 상황에 불필요하기에 비활성화로 체크해준다.

    이건 디폴트로 활성화에 체크가 되어있다.

  • 버킷 생성
    고급 설정은 따로 건드릴 필요없으니 이제 버킷을 생성해보자.

버킷이 성공적으로 생성되었다.

2. 버킷에 정적 웹 호스팅 세팅

버킷의 정적 웹 호스팅 설정은 다음과 같이 속성 탭에서 확인할 수 있다.
하지만 나는 cloudfront를 통하여 호스팅할 것이기 때문에 비활성화인채로 두겠다.

만약 cloudfront를 사용하지않고 s3만을 통해 호스팅한다면 이를 활성화시켜주면 끝이다.

3. 빌드된 정적 파일을 S3 버킷에 업로드

이제 리액트로 빌드한 정적 파일을 s3에 업로드해보자.

빌드 디렉터리에 있는 정적 파일들을 업로드해준다.

조금의 시간 뒤 잘 업로드되었다.

4. CloudFront 배포 생성

  • CloudFront 배포 생성
    이제 s3에 업로드된 정적 파일을 cloudfront를 통해 배포해보자.
    프리티어면 다음과 같은 조건하에 서비스를 이용할 수 있다.
    CloudFront 배포 생성 버튼을 누른다.

  • 원본 도메인 선택
    원본 도메인에서 방금 내가 만든 s3 버킷에 대한 도메인을 선택한다.

  • S3 버킷 엑세스
    s3 버킷에 접근 권한을 설정하는 부분인데 cloudfront에서만 접근할 수 있게 할 것이므로 원본 엑세스 제어 설정(권장)을 선택해준다.

  • Origin Sheid
    Origin Sheid는 를 선택함으로써 활성화해준다.
    이는 네트워크의 성능을 높여주는 기능이라고 생각하면 된다.

  • 기본 캐시 동작
    다른 부분들은 기본값으로 두고 뷰어 프로토콜 정책만 Redirect Http to Https를 선택해준다.
    이는 http로 접속했을 때 https로 접속하게 해주는 기능이다.

  • 캐시 키 및 원본 요청
    이 부분 또한 recommended로 선택되어있는 부분을 선택해준다.
    그리고 제어 설정 생성을 누른 뒤 생성버튼을 눌러준다.

  • 설정
    설정 옵션 중에 여러가지 옵션이 있는데 이 중 기본값 루트 객체-선택 사항 이 부분에만 index.html을 입력해준다.
    나머지 옵션은 기본으로 선택되어있는 상태로 선택해준다.

기본 루트로 접속하였을 때 index.html을 자동으로 반환해주기 위하여!

  • 배포 생성

이제 배포생성 버튼을 통해 해주자.

3. s3 버킷 정책 업데이트

생성하고 난뒤 다음과 같은 메시지가 나타났다.

cloudfront에서 s3에 접근하게 하기 위해서는 s3 정책을 업데이트를 해줘야한다고 한다.

정책 복사버튼을 누른 뒤 s3로 이동하여 버킷 정책을 업데이트해주자.

s3로 이동한 뒤 권한 탭으로 이동한다.

그리고 버킷 정책에서 편집 버튼을 눌러준다.

아까 복사한 정책을 붙여넣어준다.

이제 변경 사항을 저장해준다.

4. 배포 uri 확인

이제 다시 cloudfront로 가서 배포된 uri를 확인해보자.

잘 접속되는 것을 확인할 수 있다.

5. 에러페이지

403

만약 유저가 index.html이 아닌 다른 페이지를 실수로 요청한다 했을 때 index.html로 리다이렉트해주도록 해보자.

  • 우선 cloudfront에서 오류 페이지 탭으로 이동한 뒤 사용자 정의 오류 응답 생성을 클릭한다.

  • http오류 코드는 403을 선택해주고 오류 페이지가 요청이 왔을 때 사용자에게 다시 index.html을 응답해주도록 설정한다.

아래와 같이 오류 응답 사용자 정의에서 를 체크해주고 응답 페이지 경로에는 /index.html을 입력해준다.

Http 응답 코드는 200을 선택해준다.

  • 잘못된 html로 접속해보기
    index.html이 아닌 test.html로 접속해도 index.html로 잘 리다이렉션해준다.

url에 다른 페이지를 입력하여도 index.html을 잘 응답해주고 있다.

마무리

이상으로 s3와 cloudfront를 통하여 리액트 프로젝트를 배포하는 방법을 살펴봤다.

나의 경우 이전에 해당 프로젝트를 netlify를 통해 배포하였는데 이미지 로딩이 느린 이슈가 있었다.

서버와의 물리적 거리 때문이다.
netlify는 한국에 서버를 두고 있지 않다.

이러한 이슈가 있기도 하고 프론트 서버를 배포하는 법을 살펴보고 있기도 하여 s3,cloudfront를 활용하여 호스팅해보았다.

결과적으로 이전보다 이미지가 매우 빨리 로딩되는 만족스러운 결과를 얻었다.

profile
FE DEVELOPER

0개의 댓글