본문 바로가기
TIL/Code States

Code States 44일차 - 클라이언트 빌드와 배포

by 죠르띠에 2021. 9. 28.

Chapter - 빌드

SSR과 CSR

What is SSR?

SSR은 Server Side Rendering의 줄임말이다. 웹 페이지를 브라우저에서 렌더링 하는 대신에, 서버에서 렌더링한다. 브라우저가 서버의 URI로 GET 요청을 보내면, 서버는 정해진 웹 페이지 파일을 브라우저로 전송한다. 그리고 서버의 웹 페이지가 브라우저에 도착하면 완전히 렌더링된다. 서버에서 웹 페이지를 브라우저로 보내기 전에, 서버에서 완전히 렌더링했기 때문에 Server Side Rendering 이라고 한다. 웹 페이지의 내용에 데이터베이스의 데이터가 필요한 경우, 서버는 데이터베이스의 데이터를 불러온 다음 웹 페이지를 완전히 렌더링 된 페이지로 변환한 후에 브라우저에 응답으로 보낸다. 브라우저가 다른 경로로 이동할 때마다 서버는 이 작업을 다시 수행한다.

SSR

What is CSR?

CSR은 Client Side Rendering을 의미한다. 일반적으로 CSR은 SSR의 반대로 여겨진다. SSR이 서버 측에서 페이지를 렌더링한다면, CSR은 클라이언트에서 페이지를 렌더링한다. 웹 개발에서 사용하는 대표적인 클라이언트는 웹 브라우저이다. 브라우저의 요청을 서버로 보내면 서버는 웹 페이지를 렌더링하는 대신, 웹 페이지의 골격이 될 단일 페이지를 클라이언트에 보낸다. 이때 서버는 웹 페이지와 함께 JavaScript 파일을 보낸다. 클라이언트가 웹 페이지를 받으면, 웹 페이지와 함께 전달된 JavaScript 파일은 브라우저에서 웹 페이지를 완전히 렌더링 된 페이지로 바꾼다.웹 페이지에서 필요한 내용이 데이터베이스에 저장된 데이터인 경우에는 브라우저가 데이터베이스에 저장된 데이터를 가져와서 웹 페이지에 렌더링을 해야한다. 이를 위해 API가 사용되고 웹 페이지를 렌더링하는 데에 필요한 데이터를 API 요청으로 해소한다. 브라우저가 다른 경로로 이동하면 SSR과 다르게 서버가 웹 페이지를 다시 보내지 않는다. 브라우저는 브라우저가 요청한 경로에 따라 페이지를 다시 렌더링한다. 이때 보이는 웹 페이지의 파일은 맨 처음 서버로부터 전달받은 웹 페이지 파일과 동일한 파일이다.

CSR

The Difference

CSR과 SSR의 주요 차이점은 페이지가 렌더링되는 위치이다. SSR은 서버에서 페이지를 렌더링하고, CSR은 브라우저(클라이언트)에서 페이지를 렌더링한다. 브라우저는 사용자가 다른 경로를 요청할 때마다 페이지를 새로고침 하지않고, 동적으로 라우팅을 관리한다.

Use SSR

  • SEO(Search Engine Optimization)가 우선순위인 경우, 일반적으로 SSR을 사용한다.
  • 웹 페이지의 첫 화면 렌더링이 빠르게 필요한 경우에도, 단일 파일의 용량이 작은 SSR이 적합하다.
  • 웹 페이지가 사용자와 상호작용이 적은 경우, SSR을 활용할 수 있다.

Use CSR

  • SEO가 우선순위가 아닌 경우, CSR을 이용할 수 있다.
  • 사이트에 풍부한 상호작용이 있는 경우, CSR은 빠른 라우팅으로 강력한 사용자 경험을 제공한다.
  • 웹 애플리케이션을 제작하는 경우, CSR을 이용해 더 나은 사용자 경험을 제공할 수 있다.

정적 웹 사이트 vs 동적 웹 사이트

정적 웹 사이트와 동적 웹 사이트

정적 웹 사이트보다 동적 웹 사이트가 좀 더 최신 기술처럼 들리지만, 현대의 2-tier Architecture에서는 정적 웹 사이트의 사용이 더욱 보편적이다.

  • 정적 웹 사이트 : HTML파일 자체로 배포되는 사이트(CSR)
  • 동적 웹 사이트 : 서버에 의해 HTML 파일이 동적으로 생성되는 사이트(SSR)

웹 사이트 렌더링 방식의 변천

AJAX 이전에는 요청에 따라 결과가 변하는 동적인 웹 페이지를 만드려면, 서버가 매번 동적으로 생성하는 수 밖에 없었다. 한편 동적으로 웹 사이트를 받아오기 위해서는, 서버가 HTML의 형태로 브라우저에 제공해주어야만 했기 때문에, 헤더나 푸터 등의 페이지 구성요소의 중복 요청/응답이 빈번했다. 따라서, 네트워크 상에서 주고받는 패킷의 크기가 다소 컸다.

이처럼 AJAX 이전에는 서버에서 웹 페이지를 만드는 기술이 보편화되었고, 이러한 동적 웹 사이트를 만드는 기술로는 PHP, JSP, ASP 등이 널리 사용되었다.

그러나, 점차 브라우저의 발달과 AJAX 기술이 보편화되면서, 모든 동적인 정보들을 서버가 부담할 필요는 없게 되었다. 필요한 부분만 클라이언트가 요청할 수 있게 되었고, 이로 인해 서버의 부하가 다소 줄어들게 되었다.

이에 따라 서버는 JSON과 같은 순수한 데이터 포맷만 제공해주는 형태로 흐름이 바뀌기 시작했으며, 클라이언트 사이드, 즉 웹 페이지는 자바스크립트와 AJAX 기술을 이용한 보다 고도화된 웹 앱, 즉 Single Page Application으로 변모하기 시작한다. 자바스크립드가 동적인 렌더링을 지원하나, 결국 서버가 웹 페이지를 렌더링하지 않으며, HTML/CSS/JS 파일의 소스 코드 그대로 작동하는 특징을 갖고 있기 때문에, 이는 정적 웹 사이트 이다.

빌드

정적 웹사이트의 빌드

현대의 웹 앱은 정적 웹페이지와 AJAX 기술을 함께 사용하며, SPA로 변모함에 따라 클라이언트 사이드의 규모가 커지게 되었다. 이 떄 웹사이트 구성요소를 각 파일로 분리하는 모듈화 가 이뤄지게 되며, React와 같은 클라이언트 기술이 발전하면서, 단일 파일로 자바스크립트나 페이지를 만드는 작업은 보다 고도화되기 시작했다.

고도화된 클라이언트 웹 앱은 수많은 모듈로 이뤄져 있다. 이처럼 수많은 모듈을 하나로 묶어주는 작업을 번들링(bundling)이라고 하며, 이 과정에서 JSX 파일과 같이 브라우저에서 자체적으로 해석이 불가능한 다양한 보조 기술들을 브라우저가 해석할 수 있도록 만들어주는 작업들이 수반된다. 이러한 과정을 통칭해 "소프트웨어빌드"라고 부른다. 소프트웨어 빌드는, 소스코드를 실행 가능한 결과물로 변환하는 작업을 의미한다.


Chapter - 배포

클라이언트 웹 앱 배포

로컬 환경에서 개발한 코드를 실제 서비스로 만들기 위해서는, 빌드 과정과 이를 웹에 노출시키는 배포 과정을 필요로 한다. 빌드를 통해 만든 정적 파일이 웹을 통해 제공(serve)되려면, 이러한 정적 파일을 제공하는 웹 서버가 필요하다.

일반적으로 웹 서버라고 하면 웹 서비스를 제공하는 모든 종류의 서버가 웹 서버일 수 있으나, 특별히 정적 파일을 제공할 수 있도록 서버의 공간을 대여해주는 서비스를 호스팅 서비스라고 부른다.

호스팅 서비스는 단순 파일을 웹에서 접근 가능하게 만들어주며, 동적 웹사이트나 (express 등을 사용한) API 서버를 제공하려면, 별도의 클라우드 컴퓨팅 서비스가 필요하다.

다양한 웹 호스팅 서비스

개발자들이 선호하고, 비교적 낮은 가격에 사용할 수 있는 다양한 웹 호스팅 서비스들이 있다.

  • Amazon Web Service (AWS) S3
  • Goole Cloud Storage
  • Vercel
  • GitHub Pages
  • Netlify
  • Heroku

SSR과 CSR의 의미를 아직도 헷갈린다. 단순히 동적 페이지가 CSR이고, 정적 페이지가 SSR인지...

회사를 다닐 때 데이터를 어디서 렌더링하느냐에 SSR과 CSR을 구분했었는데, 지금보면 그것도 아닌거 같고...

 

웹 호스팅 서비스를 보면서 AWS S3가 눈에 들어온다. S3를 어떻게 사용하면 웹서버가 될 수 있을까 고민해본다.

EC2를 많이 써보고 S3는 단순히 파일 서버로 사용해 봤는데 이 고민은 Section 3로 넘어가면 해결되지 않을까 싶다.