클라이언트 코드를
EC2에서 관리 및 배포하곤 했었는데
사실 용량도 많이 차지하고 좋은 방법은 아니라고 생각했다.
더 빠른 전달속도와 더 쉬운 프로젝트 관리를 위한 방법을 찾던중
CloudFront + Route53+ S3 + ACM(for SSL)
조합을 발견했다.
처음해보는 사람이라도 쉽게 할수있고,
효과는 눈이 번쩍일정도로 뛰어난것같다.
이에 대해 고민하던 나와 다른 분들을위해
위 조합을 이용하는 방법을 상세하게 공유하고자 한다.
1. S3
1-1) 먼저, 시작은 S3에서부터다
1-2) React 프로젝트가 있다면 빌드후 생성된 파일들을 S3에 올릴것이다.
1-3) S3 -> 버킷 만들기
1-4) 주의사항은 모든 퍼블릭 액세스 차단을 해제시킬것 (사이트는 누구나 접근가능해야하니까요)
1-4-1) 버킷 만들기
1-5) 버킷을 만들고나면 객체 탭에다가 빌드후 생성된 파일들을 드래그다운하여 업로드한다.
1-6) 다음, 권한 탭에서 버킷 정책을 생성해준다
1-6-1) 편집 -> 정책 생성기
1-6-2) Select Type of Policy: S3
1-6-3) Effect: Allow
1-6-4) Principal: *
1-6-5) Aws Service: S3
1-6-6) Actions: GetObject
1-6-7) ARN: 정책 편집 페이지에 있는 버킷ARN을 복사해 붙여넣는다. 그리고 뒤에 /*을 덧붙인다
1-6-8) ARN 예시: arn:aws:s3:::coke.cola/*
1-7) 속성탭으로 이동한다.
1-7-1) 맨 하단에 정적 웹 사이트 호스팅을 편집
1-7-2) 정적 웹사이트 호스팅 -> 활성화, 유형 -> 정적 웹사이트 호스팅, 인덱스 문서 -> index.html
1-7-3) 변경 사항 저장
여기까지 했으면 S3설정은 끝났다.
심심하다면 index.html의 객체 URL로 접근해보면 접속됨을 확인할 수 있다.
이제 누구나 쉽게 접속할수있게 도메인을 설정해주는 것과 좀더 빠른 페이지를 위한 CloundFront 적용이 남았다.
아, 안전한 서비스 제공을 위한 SSL도 필수니까 당연히 진행하는거로
이전 포스팅에서 했던것처럼 ACM(Certificate Manager)을 통해 SSL 인증서를 생성해보자
2. SSL 인증
2-1) ACM (Certificate Manager)에 접속
2-2) 인증서 요청 -> 공인 인증서 요청
2-3) 도메인 이름 사용하고자 하는거로 입력 (S3에 저장한 사이트를 운영하고자하는 사이트 도메인), (구매해둔 도메인은 있다는 가정)
2-4) DNS 검증 -> 태그 설정 (내가 식별을 위한거니까 영문으로 알아볼수 있게 쓰면됨)
2-5) 검토를 하고나서 생성된 정보를 기반으로 Route 53에 해당 CNAME을 등록해주면 됩니다.
SSL은 간단히 이정도만 해주면 끝입니다.
그러면 잠시 뒤 발급완료 처리가 됩니다.
다음 순서는 CloudFront입니다.
S3에서 파일을 제공하는것보다 빠를 뿐아니라, SSL을 연결해주는것도 쉽게 가능합니다.
3. CloudFront 설정하기 - 조금 번거로움
3-1) CloudFront 접속
3-2) Create distribution
3-2-1) Origin Domain 검색 (로딩이 좀 걸립니다) -> S3 버킷이 나타나면 클릭
3-2-2) Viewer protocol policy: Redirect HTTP to HTTPS
3-2-3) Custom SSL certificate - optional: 이전에 생성해둔거로 지정
3-2-4) Default root object: index.html
3-2-5) Create distribution
3-3) 생성됐다면, 도메인을 설정해줄건데요. 다시 Roue53에 해당 호스팅 영역으로 갑니다.
3-3-1) 레코드 생성 - "A 유형"
3-3-2) 도메인 이름 설정 (2-3과 일치하게)
3-3-3) 트래픽 라우트 대상 -> 별칭 active -> Cloud Front 배포에 대한 별칭 선택 -> 검색란에 CloudFront의 Distribution domain name 이름 검색 및 선택
3-3-4) 3-3-1 ~ 3-3-3의 작업을 한번 더 반복하여 "AAA 유형"도 생성
3-4) 거의 끝났습니다. 다시 Clound Front로 돌아갑니다.
3-4-1) 해당 객체를 Edit
3-4-2) Alternative domain name에 "Add Item" 하여 2-3에서 만든 도메인과 동일하게 입력해줍니다.
3-4-3) 그리고 저장하면 끝
자 이제 두근두근 하면서
해당 도메인에 https://로 접속해 봅니다.
잘되나요? 잘됐길바라며 여기서 마치겠습니다.
'개발, 코딩 > AWS' 카테고리의 다른 글
서브도메인에 SSL을 설정해보자 (aws) (0) | 2021.07.14 |
---|---|
Load Balancer에서 HTTP -> HTTPS로 Redirect (1) | 2020.11.02 |
S3 API 활용하기 (목록 가져오기, 이름 변경하기) (0) | 2020.08.14 |