Update: Wikified 129 files from Datacollector_MAC/out_wiki (P-Reinforce v3.0)
This commit is contained in:
@@ -1,11 +1,82 @@
|
||||
---
|
||||
category: Unified
|
||||
tags: [auto-consolidated, technical-documentation]
|
||||
title: [[Hydration 성능 최적화|Hydration 성능 최적화]]
|
||||
last_updated: 2026-05-02
|
||||
category: Architecture
|
||||
tags: [auto-wikified, technical-documentation, merged, architecture]
|
||||
title: React Hydration
|
||||
description: "React Hydration은 서버 사이드 렌더링(SSR)을 통해 생성된 정적인 HTML 문서에 클라이언트 측 React가 이벤트 핸들러와 상호작용성을 주입하는 과정이다 [1]."
|
||||
last_updated: 2026-05-04
|
||||
---
|
||||
|
||||
# [[Hydration 성능 최적화|Hydration 성능 최적화]]
|
||||
# React Hydration
|
||||
|
||||
|
||||
## 📌 Brief Summary
|
||||
React Hydration은 서버 사이드 렌더링(SSR)을 통해 생성된 정적인 HTML 문서에 클라이언트 측 React가 이벤트 핸들러와 상호작용성을 주입하는 과정이다 [1]. 빈 화면(White Screen)을 보여주는 대신 완전히 형태를 갖춘 HTML을 사용자에게 먼저 제공하여 초기 체감 로딩 속도를 향상시키기 위해 사용된다 [1, 2]. React 코어 팀의 댄 아브라모프(Dan Abramov)는 이를 "마른(dry) HTML에 상호작용성이라는 물을 주는 것"이라고 비유했다 [1].
|
||||
|
||||
## 📖 Core Content
|
||||
* **작동 메커니즘**: 하이드레이션은 DOM을 처음부터 다시 생성(Re-rendering)하는 것이 아니다 [3]. React는 서버에서 이미 렌더링된 DOM 트리를 순회하면서, 자신이 구축 중인 Fiber 트리와 병렬로 비교한다 [3]. 각 Fiber를 기존 DOM 노드에 매칭시켜 `fiber.stateNode`에 참조를 저장한 뒤, 이벤트 리스너를 부착하고 DOM을 재사용함으로써 애플리케이션을 활성화한다 [1, 3].
|
||||
* **선택적 하이드레이션 (Selective Hydration)**: 과거에는 전체 트리가 하이드레이션될 때까지 기다려야 했지만, React 18은 Lanes 우선순위 시스템을 통해 이 과정을 개선했다 [4]. 사용자가 애플리케이션의 특정 요소와 상호작용을 시도하면, React는 진행 중이던 하이드레이션을 중단하고 `SyncLane`을 사용해 사용자가 상호작용한 경계로 점프하여 해당 부분만 우선적으로 하이드레이션한 뒤 나머지 작업을 재개한다 [4].
|
||||
* **스트리밍과 점진적 적용 (Streaming)**: 서버는 데이터가 모두 준비될 때까지 기다리지 않고 셸(Shell)을 즉시 클라이언트로 전송하며, Suspense 경계 단위로 데이터가 해결되는 대로 스트리밍한다 [4]. 클라이언트는 나머지 데이터가 도착하는 동안 이미 수신된 부분부터 점진적으로 하이드레이션을 시작할 수 있다 [4].
|
||||
* **클라이언트 컴포넌트와 서버 컴포넌트의 차이**: 클라이언트 컴포넌트(Client Components)는 서버에서 먼저 실행된 후 클라이언트에서 하이드레이션을 위해 다시 한 번 실행된다 [5, 6]. 반면, React 서버 컴포넌트(RSC)는 오직 서버에서만 실행되므로 클라이언트 측의 하이드레이션 단계 자체가 존재하지 않는다 [6].
|
||||
|
||||
## ⚖️ Trade-offs & Caveats
|
||||
* **하이드레이션 갭 (The Hydration Gap)**: SSR과 하이드레이션은 사용자가 페이지를 더 빨리 볼 수 있게 하지만, **화면이 완성되어 보임에도 실제로는 상호작용할 수 없는 '착시 구간'**을 만들어낸다 [3, 7]. 이벤트 리스너가 부착되기 전까지는 버튼을 클릭하거나 드롭다운을 눌러도 애플리케이션이 아무런 반응을 하지 않는다 [7].
|
||||
* **전체 트리 순회에 따른 블로킹**: 기본적으로 React는 트리를 순차적으로 순회하며 하이드레이션을 진행하기 때문에, 트리 상단에 처리 속도가 느린 컴포넌트가 하나라도 있으면 하단 요소의 클릭 핸들러 부착까지 전체적으로 지연되는 병목 현상이 발생한다 [3].
|
||||
* **이중 작업과 자바스크립트 번들 비용 (The Two-Trip Lie)**: 서버에서 HTML을 먼저 렌더링하더라도, 결국 상호작용을 위해 클라이언트는 전체 자바스크립트 번들을 그대로 다운로드하고 파싱해야 한다 [8, 9]. 서버에서 데이터를 페칭하여 HTML을 완성했음에도 불구하고, 클라이언트가 다시 동일한 컴포넌트를 실행하게 되므로 전체적인 클라이언트 작업량이나 JavaScript 번들 크기는 감소하지 않는다는 근본적인 한계가 있다 [8]. (이러한 단점을 해결하기 위해 등장한 것이 React 서버 컴포넌트이다 [9].)
|
||||
|
||||
---
|
||||
*Last updated: 2026-05-03*
|
||||
|
||||
## 📚 Legacy Insights & Additional Context
|
||||
> [!NOTE]
|
||||
> Below is content merged from previous versions of this documentation.
|
||||
|
||||
## 📌 Brief Summary
|
||||
지연 하이드레이션(Lazy Hydration)은 Vue 3.5에서 서버 사이드 렌더링(SSR)을 위해 도입된 성능 최적화 기능입니다 [1]. 이 기능은 컴포넌트가 화면(뷰포트)에 표시될 때만 하이드레이션이 수행되도록 활성화를 지연시킵니다 [1, 2]. 이를 통해 불필요한 초기 연산을 방지하여 초기 로드 시간을 단축하고 전반적인 사용자 경험을 향상시킵니다 [1, 3].
|
||||
|
||||
## 📖 Core Content
|
||||
* **동작 메커니즘 및 성능 향상:** 지연 하이드레이션은 SSR 환경에서 컴포넌트가 사용자의 뷰포트 내에 들어오기 전까지는 활성화(하이드레이션)를 미루는 방식으로 작동합니다 [1, 2]. 이 전략은 애플리케이션의 초기 페이지 로드 시간을 감소시키고 Vue.js의 렌더링 성능을 향상시키는 데 직접적으로 기여합니다 [1, 2].
|
||||
* **주요 적용 분야:** 이 패턴은 빠른 로딩 시간과 검색 엔진 최적화(SEO)가 비즈니스 성공에 필수적인 콘텐츠 관리 시스템(CMS), 이커머스 사이트, 미디어 플랫폼 등 콘텐츠가 풍부한 대규모 웹 애플리케이션에서 매우 유용합니다 [4].
|
||||
* **사용자 경험(UX) 개선:** 컴포넌트를 실제로 필요한 시점에만 활성화함으로써 대규모 애플리케이션 환경에서도 사용자에게 훨씬 더 부드러운 상호작용(Interaction) 경험을 제공할 수 있습니다 [3]. 빠른 초기 화면 로딩을 달성하면서도 대화형 기능들을 무리 없이 유지할 수 있도록 돕습니다 [4].
|
||||
|
||||
## ⚖️ Trade-offs & Caveats
|
||||
소스에 관련 정보가 부족합니다. (제공된 소스 데이터 내에는 'Lazy Hydration' 기법 적용에 따른 구체적인 기술적 부작용, 제약 사항 또는 반대 급부에 대한 내용이 포함되어 있지 않습니다.)
|
||||
|
||||
---
|
||||
*Last updated: 2026-05-03*
|
||||
|
||||
## 📚 Legacy Insights & Additional Context
|
||||
> [!NOTE]
|
||||
> Below is content merged from previous versions of this documentation.
|
||||
|
||||
## 📌 Brief Summary
|
||||
하이드레이션(Hydration)은 프론트엔드 프레임워크가 서버 사이드 렌더링(SSR)을 통해 생성된 정적 HTML을 클라이언트에서 넘겨받아 이벤트 핸들러를 연결하고 상호작용성(Interactivity)을 부여하는 과정입니다 [1]. 이는 '건조한(dry)' HTML에 상호작용성이라는 '물(water)'을 주는 것에 비유됩니다 [1]. 사용자에게 화면을 더 빨리 보여줄 수 있다는 장점이 있지만, 최적화되지 않을 경우 페이지가 렌더링된 후 상호작용이 가능해질 때까지의 지연(하이드레이션 갭)이 발생하는 한계도 지니고 있습니다 [2].
|
||||
|
||||
## 📖 Core Content
|
||||
* **하이드레이션의 동작 원리**
|
||||
하이드레이션은 처음부터 DOM을 다시 생성하는 재렌더링(re-rendering) 작업이 아닙니다 [3]. 예를 들어 React는 기존에 서버가 렌더링한 DOM 트리를 순회하면서 생성 중인 Fiber 트리와 대조(matching)하여 기존 DOM을 재사용하고 이벤트 리스너만 연결하는 방식으로 작동하므로, 완전히 새로 렌더링하는 것보다 빠릅니다 [1, 3].
|
||||
|
||||
* **프레임워크별 하이드레이션 최적화 전략**
|
||||
* **React 18의 선택적 하이드레이션(Selective Hydration)**: 기존의 하이드레이션은 순차적으로 진행되었으나, React 18부터는 우선순위(Lanes) 시스템을 도입하여 사용자가 클릭 등 상호작용을 시도하면 해당 부분의 하이드레이션을 우선적으로 처리한 뒤 나머지 트리의 작업을 재개할 수 있습니다 [4].
|
||||
* **스트리밍(Streaming)과의 결합**: 서버가 모든 데이터를 기다리지 않고 UI 셸(Shell)을 먼저 보낸 뒤 데이터가 해결되는 대로 청크 단위로 스트리밍하면, 클라이언트는 나머지 데이터가 도착하는 중에도 이미 도착한 부분부터 하이드레이션을 시작할 수 있습니다 [4].
|
||||
* **Vue 3.5의 지연 하이드레이션(Lazy Hydration)**: Vue 3.5는 서버 사이드 렌더링 시 컴포넌트가 뷰포트에 표시될 때만 하이드레이션되도록 지연시키는 기능을 도입했습니다 [5]. 이를 통해 초기 로드 시간을 줄이고 불필요한 활성화를 지연시켜 애플리케이션의 성능을 향상시킵니다 [5, 6].
|
||||
|
||||
* **서버 컴포넌트(RSC)를 통한 하이드레이션 제거**
|
||||
React 서버 컴포넌트(RSC)는 오직 서버에서만 실행되며 클라이언트로 전송되는 자바스크립트 번들에 포함되지 않습니다 [7, 8]. 따라서 클라이언트에서 다시 실행되거나 하이드레이션할 필요가 없어 하이드레이션 비용 자체를 완전히 제거하고 초기 로딩 및 상호작용 속도를 향상시킬 수 있습니다 [7, 9].
|
||||
|
||||
## ⚖️ Trade-offs & Caveats
|
||||
* **하이드레이션 갭(Hydration Gap)**
|
||||
전통적인 SSR과 하이드레이션 방식에서는 서버가 렌더링한 HTML이 클라이언트에 표시될 때 "페이지가 준비된 것처럼 보이지만 실제로는 그렇지 않은" 상태가 존재합니다 [2]. React가 이벤트 리스너를 완전히 부착하기 전까지는 사용자가 버튼을 클릭하거나 폼을 제출하려고 해도 아무런 반응이 없는 현상이 발생합니다 [2].
|
||||
* **전체 트리 블로킹(Blocking) 문제**
|
||||
기본적인 하이드레이션 과정에서는 전체 트리의 하이드레이션이 완료되기 전까지는 UI의 어떤 부분도 상호작용할 수 없습니다 [3]. 만약 트리 상단에 처리 속도가 느린 컴포넌트가 존재한다면, 트리 하단에 있는 단순한 버튼의 클릭 핸들러조차 작동하지 못하게 막는 병목 현상을 초래합니다 [3].
|
||||
* **자바스크립트 번들 크기 문제 유지**
|
||||
SSR과 하이드레이션의 조합은 초기 빈 화면을 해결해 주지만, 결국 서버에서 렌더링된 모든 컴포넌트의 자바스크립트 코드를 클라이언트가 다운로드하고 실행해야 합니다 [10]. 결과적으로 서버 작업이 클라이언트의 연산량이나 자바스크립트 번들 크기를 줄여주지는 못한다는 근본적인 제약이 있습니다 [10, 11].
|
||||
|
||||
---
|
||||
*Last updated: 2026-05-03*
|
||||
|
||||
## 📚 Legacy Insights & Additional Context
|
||||
> [!NOTE]
|
||||
> Below is content merged from previous versions of this documentation.
|
||||
|
||||
## 📌 Brief Summary
|
||||
[[Hydration|Hydration]]은 서버에서 렌더링된 정적 HTML 뼈대에 JavaScript를 실행하고 이벤트 리스너를 연결하여 완전한 상호작용이 가능한 애플리케이션으로 변환하는 과정입니다 [1, 2]. 기본적으로 React는 페이지 전체를 한 번에 Hydration하면서 메인 스레드를 차단하여 TBT(Total Blocking Time)와 TTI(Time to Interactive) 지표를 악화시킬 수 있습니다 [3]. 이를 해결하기 위해 선택적 Hydration, 지연 로딩, [[React Server Components|React Server Components]](RSC) 등의 최적화 기법을 도입하여 초기 로드 성능과 상호작용성을 극대화할 수 있습니다 [4-6].
|
||||
|
||||
Reference in New Issue
Block a user