오늘은 Next.js를 공부하면서 알게 된 SSR과 CSR에 대해서 설명을 하겠다.
먼저 SSR에 대해서 설명하겠다.
SSR이란?
SSR은 Server Side Rendering
의 약자이다.
SSR은 전통적인 웹 애플리케이션 렌더링 방식으로 사용자가 웹 페이지에 접근할 때, 서버에 페이지에 대한 요청을 하게 된다.
이때, 서버에서는 HTML, View와 같은 자원(Resource) 들을 어떻게 보여 줄지 해석하고 렌더링 하여 사용자에게 반환한다.
참고로 웹 서버에 요청할 때마다 브라우저에게 새로고침이 일어나게 되고, 서버에 새로운 페이지에 대한 요청을 하는 방식이다.
SSR의 장점?
- 검색 엔진 최적화(SEO) 가능
SSR의 가장 큰 장점 중 하나다. SEO에 대해서는 아래에서 설명하겠다.
- 초기 로딩 속도가 빠름
처음 렌더링 된 HTML을 클라이언트에게 전달해주기 때문에 초기 로딩 속도를 줄일 수 있다.
또한, JavaScript 파일을 불러오고 렌더링 작업이 완료되지 않아도 사용자가 콘텐츠를 이용할 수 있다.
SSR의 단점?
- 프로젝트 구조가 복잡해진다.
단순 렌더링만 하면 큰 문제가 발생하지 않지만 Redux
, React Router 등
여러 라이브러리와 함께 연동하여 서버에서 데이터를 가져와 렌더링 하는 상황이 발생하면, 프로젝트 구조가 많이 복잡해질 수 있다.
- 매번 새로고침이 발생한다.
위에서 언급한 듯이, SSR은 서버에 요청할 때마다 새로고침이 발생한다. 매번 새로고침이 발생한다는 것은 서버와 잦은 응답을 한다는 뜻이다. 이렇게 되면 자연스럽게 서버에 부담을 주게 된다. 서버에 부담이 가게 된다면 당연히 성능이 악화되기 마련이다.
검색 엔진 최적화(SEO)가 무엇인가?
Search Engine Optimization
의 약어로 웹 페이지 검색 엔진이 자료를 수집하고 순위를 매기는 방식에 맞게 페이지를 구성하여 검색 결과의 상위에 나올 수 있도록 하는 작업을 말한다.
검색 결과가 상위에 나오게 된다면 방문 트래픽이 늘어난다. 이렇기 때문에 인터넷 마케팅의 수단으로 이용되기도 한다.
SCR이란?
SCR에 대해 알아보기 전에 SPA라는 거부터 알아보자.
- SPA(Single Page Application)의 등장 배경과 개념
앞의 SSR은 기존에 존재하는 방식이라고 언급하였다. 그러다 기술의 발전으로 모바일 시대가 도래하면서 모바일 환경에 최적화된 서비스가 필요해졌다. 하지만 일 번 적인 컴퓨터에 비해 성능이 낮은 모바일에 최적화시키는 일이란 매우 어려운 일이었고, 기존과 다른 방식이 필요했다. 그래서 등장한 개념이 SPA다.
SPA는 최초 한번 페이지 전체를 로딩한 이후부터는 데이터만 변경하여 사용하는 단일 페이지로 구성된 웹 애플리케이션이다. SPA에서는 화면 구성에 필요한 모든 HTML을 클라이언트가 갖고 있고, 서버 측에는 필요한 데이터를 요청하고, JSON으로 받기 때문에 기존의 애플리케이션에 비해 화면을 구성하는 속도가 빠르다.
전통적인 웹 렌더링 방식인 SSR은 SPA에 비해 성능이 떨어졌다. 가장 큰 이유는 요청 시마다 서버로부터 Resource를 받아 해석하고 화면에 렌더링 하기 때문이다. (단점으로 언급한 요청 시마다 새로고침이 되는 것) 이런 단점을 보완하고자 SPA는 트래픽을 감소시키고 사용자에게 최적화된 환경을 제공할 수 있게 되었다. 서버에서는 JSON 파일을 보내는 역할만 하며, HTML을 그리는 역할은 클라이언트 측에서 JavaScript가 수행한다. 이것이 바로 CSR이다.
Client Side Rendering (CSR)
- 클라이언트에서 렌더링 하는 방식
SPA부분에서 언급한 내용과 겹치지만, 다시 한번 각인을 시켜보다. CSR은 클라이언트 측에서 최초 1번, 서버에서 전체 페이지를 로딩하여 보여준다. 그 이후에는 사용자의 요청이 올 때마다, Resource를 서버에서 제공한 후, 클라이언트가 해석하고 렌더링 하는 방식이다. 참고로 여기에 Angular.js
와 같이 SPA 개발에 최적화된 JavaScript 프레임워크가 등장했는데, 다시 클라이언트가 무거워지자 다시 View로만 관리하자는 의견에 의해 React.js
가 등장하였다.
- SCR의 과정
- 처음 웹 서버에 요청할 때, 데이터가 없는 문서를 반환한다.
- HTML 및 static 파일들이 로드된다. 이때, 데이터가 있다면 데이터 또한 서버에 요청하여 화면에 나타낸다.
- 브라우저가 서버에 HTML과 static 파일을 요청한 후 로드되면, 사용자의 상호작용에 따라 JavaScript를 통해 동적으로 렌더링을 한다.
- 필요에 따라 데이터를 서버에 요청해서 받아와 렌더링 한다.
React.js를 사용하는 이유는??
- React.js의 장점
SSR과 달리 CSR 방식은 서버로부터 데이터를 받아 클라이언트에서 렌더링 하는 방식이다.
때문에 아래와 같은 장점을 가진다.
바뀐 부분만 렌더링한다.
Component를 나눠서 관리가 가능하다.
코드의 재사용성을 높여준다.
- 가상 DOM
기존에는 DOM 전체를 직접 접근하여 조작한 후, 브라우저에서 화면을 나타내는 방식이었다. 하지만 이 방식은 HTML, CSS, JavaScript 파일을 리 렌더링 하기 때문에 느려지는 단점이 있다. 그래서 페이스북에선 React.js
를 View의 변형이 아닌 기존 뷰를 날리고 가상 DOM을 이용하여 실제 DOM을 조작하는 횟수를 줄여 성능을 개선시켰다. 참고로 데이터가 변경되면 React.js
에선 가상 DOM을 다시 변경하고, 이전의 가상 DOM과 비교하여 변경된 부분을 체크하고 변경된 부분만 실제 DOM에 적용한다.
CSR의 장점
- 트래픽 감소와 빠른 인터랙션
아까 SSR은 서버와 잦은 응답 때문에 자연스럽게 서버에 부담을 준다고 했다. 반면, CSR은 사용자의 행동에 따라 필요한 부분만 다시 읽어 들이기 때문에 서버 측에서 전체 페이지를 다시 읽어 들이는 것보다 빠른 인터랙션이 가능하다. 즉, 필요하고 변경된 데이터만 받아올 수 있다는 의미다. 물론 서버의 부담도 줄일 수 있다.
CSR의 단점
- 초기 구동 속도가 느리다.
SSR은 View를 서버에서 렌더링 하여 가져오기 때문에 초기 구동 속도가 빠르다고 했다. 하지만 CSR은 서버에서 View를 렌더링 하지 않는다. 위에서 여러 번 언급하여 지겹겠지만 CSR은 HTML, JavaScript 파일, 각종 Resource를 다운로드한 후에 브라우저에서 렌더링을 하기 때문에 초기 구동 속도가 느리다.
- 검색 엔진 최적화(SEO)가 어렵다.
CSR방식으로 이루어진 웹 페이지에서는 View를 생성하기 위해선 반드시 JavaScript를 실행시켜야 한다. 하지만, 대부분 웹 크롤러 봇들은 JavaScript 파일을 실행시키지 못하기 때문에 HTML에서만 콘텐츠들을 수집하게 되고, CSR페이지를 빈 페이지로 인식하게 된다.
- 보안 문제가 있다.
SSR은 사용자 정보를 서버 측에서 세션으로 관리를 하지만, CSR은 쿠키 말고는 사용자 정보를 저장할 공간이 마땅치 않다.
웹 크롤러 (Web Crawler)??
- 웹 크롤러는 방대한 웹 페이지를 두루두루 방문하여, 각종 정보를 자동적으로 수집하는 일을 하는 프로그램으로써 검색 엔진의 근간이 된다. 웹 크롤러에 대한 다른 용어로는
앤트(Ants)
,자동 인덱서(Automatic Indexers)
,봇(Bots)
,웜(Worms)
,웹 스파이더(Web Spider)
,웹 로봇(Web Robot)
등이 있다. - 웹 크롤러가 하는 작업을
웹 크롤링(Web Crawling)
혹은스파이더 링(Spidering)
이라고 불리며, 검색 엔진과 같은 여러 사이트에서는 데이터의 최신 상태 유지를 위해 항상 웹 크롤링을 한다.
SSR vs CSR 정리
SSR
서버에서 렌더링을 작업하는 렌더링 방식, 전통적인 웹 애플리케이션 렌더링 방식으로 사용자가 웹 페이지에 접근할 때, 서버에 각각의 페이지에 대한 요청을 하며, 서버에서 HTML 및 JavaScript 파일 등을 모두 다운로드해서 화면에 렌더링 하는 방식.
SSR은 초기 로딩 속도가 빠르고 SEO에 유리하다.
하지만, View를 변경할 때, 서버에 계속 요청해야 하므로 서버에 부담을 준다.
CSR
Client Side Rendering은 SPA로, 클라이언트 측에서 HTML을 반환한 후에, JavaScript가 동작하면서 데이터만 주고받아 클라이언트에서 렌더링을 진행하는 방식.
초기 로딩 후, 서버에 재 요청을 할 필요 없이 클라이언트 내에서 작업이 이뤄지므로 빠르다.
하지만, 서버에서 View를 렌더링 하지 않고, 여러 Resource들을 다운로드하고 난 후 렌더링 하는 방식이기에 초기 로딩 속도가 느리고, SEO에 대한 문제가 있다.
결론
SSR과 CSR을 적절히 활용해야 한다.
다양한 라이브러리를 통해 SSR과 CSR의 방식 모두 구성하는 방법이 존재한다.
'Study > Front-End' 카테고리의 다른 글
Next.js란? (0) | 2022.01.22 |
---|---|
React Study (0) | 2021.12.03 |