feat: Wiki 지식 자산 업데이트 - UX Scenarios, Frontend, Game Design, Topics 추가 [2026-05-08]
This commit is contained in:
@@ -1,24 +1,36 @@
|
||||
---
|
||||
id: wiki-2026-0508-hydration
|
||||
title: Hydration
|
||||
category: Architecture
|
||||
status: needs_review
|
||||
canonical_id: self
|
||||
aliases: []
|
||||
duplicate_of: none
|
||||
source_trust_level: A
|
||||
confidence_score: 0.92
|
||||
tags: [auto-wikified, technical-documentation, merged, architecture]
|
||||
title: React Hydration
|
||||
description: "React Hydration은 서버 사이드 렌더링(SSR)을 통해 생성된 정적인 HTML 문서에 클라이언트 측 React가 이벤트 핸들러와 상호작용성을 주입하는 과정이다 [1]."
|
||||
last_updated: 2026-05-04
|
||||
raw_sources: []
|
||||
last_reinforced: 2026-05-08
|
||||
github_commit: pending
|
||||
inferred_by: Claude Opus 4.7 (auto-normalize 2026-05-08)
|
||||
tech_stack:
|
||||
language: unspecified
|
||||
framework: unspecified
|
||||
---
|
||||
|
||||
# React Hydration
|
||||
|
||||
|
||||
## 📌 Brief Summary
|
||||
## 📌 한 줄 통찰 (The Karpathy Summary)
|
||||
React Hydration은 서버 사이드 렌더링(SSR)을 통해 생성된 정적인 HTML 문서에 클라이언트 측 React가 이벤트 핸들러와 상호작용성을 주입하는 과정이다 [1]. 빈 화면(White Screen)을 보여주는 대신 완전히 형태를 갖춘 HTML을 사용자에게 먼저 제공하여 초기 체감 로딩 속도를 향상시키기 위해 사용된다 [1, 2]. React 코어 팀의 댄 아브라모프(Dan Abramov)는 이를 "마른(dry) HTML에 상호작용성이라는 물을 주는 것"이라고 비유했다 [1].
|
||||
|
||||
## 📖 Core Content
|
||||
## 📖 구조화된 지식 (Synthesized 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
|
||||
## ⚠️ 모순 및 업데이트 (Contradictions & Updates)
|
||||
* **하이드레이션 갭 (The Hydration Gap)**: SSR과 하이드레이션은 사용자가 페이지를 더 빨리 볼 수 있게 하지만, **화면이 완성되어 보임에도 실제로는 상호작용할 수 없는 '착시 구간'**을 만들어낸다 [3, 7]. 이벤트 리스너가 부착되기 전까지는 버튼을 클릭하거나 드롭다운을 눌러도 애플리케이션이 아무런 반응을 하지 않는다 [7].
|
||||
* **전체 트리 순회에 따른 블로킹**: 기본적으로 React는 트리를 순차적으로 순회하며 하이드레이션을 진행하기 때문에, 트리 상단에 처리 속도가 느린 컴포넌트가 하나라도 있으면 하단 요소의 클릭 핸들러 부착까지 전체적으로 지연되는 병목 현상이 발생한다 [3].
|
||||
* **이중 작업과 자바스크립트 번들 비용 (The Two-Trip Lie)**: 서버에서 HTML을 먼저 렌더링하더라도, 결국 상호작용을 위해 클라이언트는 전체 자바스크립트 번들을 그대로 다운로드하고 파싱해야 한다 [8, 9]. 서버에서 데이터를 페칭하여 HTML을 완성했음에도 불구하고, 클라이언트가 다시 동일한 컴포넌트를 실행하게 되므로 전체적인 클라이언트 작업량이나 JavaScript 번들 크기는 감소하지 않는다는 근본적인 한계가 있다 [8]. (이러한 단점을 해결하기 위해 등장한 것이 React 서버 컴포넌트이다 [9].)
|
||||
@@ -30,15 +42,15 @@ React Hydration은 서버 사이드 렌더링(SSR)을 통해 생성된 정적인
|
||||
> [!NOTE]
|
||||
> Below is content merged from previous versions of this documentation.
|
||||
|
||||
## 📌 Brief Summary
|
||||
## 📌 한 줄 통찰 (The Karpathy Summary)
|
||||
지연 하이드레이션(Lazy Hydration)은 Vue 3.5에서 서버 사이드 렌더링(SSR)을 위해 도입된 성능 최적화 기능입니다 [1]. 이 기능은 컴포넌트가 화면(뷰포트)에 표시될 때만 하이드레이션이 수행되도록 활성화를 지연시킵니다 [1, 2]. 이를 통해 불필요한 초기 연산을 방지하여 초기 로드 시간을 단축하고 전반적인 사용자 경험을 향상시킵니다 [1, 3].
|
||||
|
||||
## 📖 Core Content
|
||||
## 📖 구조화된 지식 (Synthesized Content)
|
||||
* **동작 메커니즘 및 성능 향상:** 지연 하이드레이션은 SSR 환경에서 컴포넌트가 사용자의 뷰포트 내에 들어오기 전까지는 활성화(하이드레이션)를 미루는 방식으로 작동합니다 [1, 2]. 이 전략은 애플리케이션의 초기 페이지 로드 시간을 감소시키고 Vue.js의 렌더링 성능을 향상시키는 데 직접적으로 기여합니다 [1, 2].
|
||||
* **주요 적용 분야:** 이 패턴은 빠른 로딩 시간과 검색 엔진 최적화(SEO)가 비즈니스 성공에 필수적인 콘텐츠 관리 시스템(CMS), 이커머스 사이트, 미디어 플랫폼 등 콘텐츠가 풍부한 대규모 웹 애플리케이션에서 매우 유용합니다 [4].
|
||||
* **사용자 경험(UX) 개선:** 컴포넌트를 실제로 필요한 시점에만 활성화함으로써 대규모 애플리케이션 환경에서도 사용자에게 훨씬 더 부드러운 상호작용(Interaction) 경험을 제공할 수 있습니다 [3]. 빠른 초기 화면 로딩을 달성하면서도 대화형 기능들을 무리 없이 유지할 수 있도록 돕습니다 [4].
|
||||
|
||||
## ⚖️ Trade-offs & Caveats
|
||||
## ⚠️ 모순 및 업데이트 (Contradictions & Updates)
|
||||
소스에 관련 정보가 부족합니다. (제공된 소스 데이터 내에는 'Lazy Hydration' 기법 적용에 따른 구체적인 기술적 부작용, 제약 사항 또는 반대 급부에 대한 내용이 포함되어 있지 않습니다.)
|
||||
|
||||
---
|
||||
@@ -48,10 +60,10 @@ React Hydration은 서버 사이드 렌더링(SSR)을 통해 생성된 정적인
|
||||
> [!NOTE]
|
||||
> Below is content merged from previous versions of this documentation.
|
||||
|
||||
## 📌 Brief Summary
|
||||
## 📌 한 줄 통찰 (The Karpathy Summary)
|
||||
하이드레이션(Hydration)은 프론트엔드 프레임워크가 서버 사이드 렌더링(SSR)을 통해 생성된 정적 HTML을 클라이언트에서 넘겨받아 이벤트 핸들러를 연결하고 상호작용성(Interactivity)을 부여하는 과정입니다 [1]. 이는 '건조한(dry)' HTML에 상호작용성이라는 '물(water)'을 주는 것에 비유됩니다 [1]. 사용자에게 화면을 더 빨리 보여줄 수 있다는 장점이 있지만, 최적화되지 않을 경우 페이지가 렌더링된 후 상호작용이 가능해질 때까지의 지연(하이드레이션 갭)이 발생하는 한계도 지니고 있습니다 [2].
|
||||
|
||||
## 📖 Core Content
|
||||
## 📖 구조화된 지식 (Synthesized Content)
|
||||
* **하이드레이션의 동작 원리**
|
||||
하이드레이션은 처음부터 DOM을 다시 생성하는 재렌더링(re-rendering) 작업이 아닙니다 [3]. 예를 들어 React는 기존에 서버가 렌더링한 DOM 트리를 순회하면서 생성 중인 Fiber 트리와 대조(matching)하여 기존 DOM을 재사용하고 이벤트 리스너만 연결하는 방식으로 작동하므로, 완전히 새로 렌더링하는 것보다 빠릅니다 [1, 3].
|
||||
|
||||
@@ -63,7 +75,7 @@ React Hydration은 서버 사이드 렌더링(SSR)을 통해 생성된 정적인
|
||||
* **서버 컴포넌트(RSC)를 통한 하이드레이션 제거**
|
||||
React 서버 컴포넌트(RSC)는 오직 서버에서만 실행되며 클라이언트로 전송되는 자바스크립트 번들에 포함되지 않습니다 [7, 8]. 따라서 클라이언트에서 다시 실행되거나 하이드레이션할 필요가 없어 하이드레이션 비용 자체를 완전히 제거하고 초기 로딩 및 상호작용 속도를 향상시킬 수 있습니다 [7, 9].
|
||||
|
||||
## ⚖️ Trade-offs & Caveats
|
||||
## ⚠️ 모순 및 업데이트 (Contradictions & Updates)
|
||||
* **하이드레이션 갭(Hydration Gap)**
|
||||
전통적인 SSR과 하이드레이션 방식에서는 서버가 렌더링한 HTML이 클라이언트에 표시될 때 "페이지가 준비된 것처럼 보이지만 실제로는 그렇지 않은" 상태가 존재합니다 [2]. React가 이벤트 리스너를 완전히 부착하기 전까지는 사용자가 버튼을 클릭하거나 폼을 제출하려고 해도 아무런 반응이 없는 현상이 발생합니다 [2].
|
||||
* **전체 트리 블로킹(Blocking) 문제**
|
||||
@@ -78,7 +90,7 @@ React Hydration은 서버 사이드 렌더링(SSR)을 통해 생성된 정적인
|
||||
> [!NOTE]
|
||||
> Below is content merged from previous versions of this documentation.
|
||||
|
||||
## 📌 Brief Summary
|
||||
## 📌 한 줄 통찰 (The Karpathy 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].
|
||||
|
||||
---
|
||||
@@ -89,7 +101,7 @@ Hydration(하이드레이션)은 React가 서버에서 렌더링된 정적 HTML
|
||||
|
||||
하이드레이션(Hydration)은 서버에서 사전 렌더링된 정적 HTML을 클라이언트가 전달받은 후, [[JavaScript|JavaScript]]를 실행하여 이벤트 리스너와 상태를 연결함으로써 완전한 상호작용이 가능한 애플리케이션으로 변환하는 과정입니다 [1]. SSR(Server-Side Rendering)의 빠른 콘텐츠 표시 장점과 CSR(Client-Side Rendering)의 상호작용성을 결합하지만, 하이드레이션이 완료되기 전까지는 사용자의 입력에 응답하지 않아 지연이 발생할 수 있습니다 [1-5].
|
||||
|
||||
## 📖 Core Content
|
||||
## 📖 구조화된 지식 (Synthesized Content)
|
||||
* **Hydration의 개념 및 주요 성능 병목 현상:**
|
||||
* Hydration은 SSR(Server-Side Rendering) 환경에서 서버가 생성한 HTML을 클라이언트가 넘겨받아 상호작용을 부여하는 필수적인 과정입니다 [2, 3].
|
||||
* 문제는 React가 기본적으로 시야에 보이지 않는 컴포넌트까지 포함하여 페이지 전체를 한 번에 Hydration 하려 한다는 점입니다 [3]. 이로 인해 JavaScript 실행이 메인 스레드를 장시간 점유하게 되고, 결과적으로 TBT(Total Blocking Time), FID(First Input Delay), TTI(Time to Interactive) 등의 핵심 웹 성능 지표가 크게 저하되며 사용자의 입력 지연을 초래합니다 [3, 7].
|
||||
@@ -135,10 +147,10 @@ Hydration(하이드레이션)은 React가 서버에서 렌더링된 정적 HTML
|
||||
* **스트리밍 및 Suspense:** React의 Suspense API를 사용하여 서버에서 HTML을 점진적으로 스트리밍 처리합니다 [14].
|
||||
* **[[React Server Components (RSC)|React Server Components (RSC]]:** 클라이언트 측으로 전송되는 JavaScript를 완전히 없애고 오직 서버에서만 실행되게 함으로써, 해당 컴포넌트들에 대해서는 하이드레이션 과정 자체를 생략합니다 [15-23].
|
||||
|
||||
## ⚖️ Trade-offs & Caveats
|
||||
## ⚠️ 모순 및 업데이트 (Contradictions & Updates)
|
||||
No trade-offs available.
|
||||
|
||||
## 🔗 Knowledge Connections
|
||||
## 🔗 지식 연결 (Graph)
|
||||
- **Related Topics:** [[Server-Side Rendering (SSR)|Server-Side Rendering (SSR]], React Server Components (RSC), Total Blocking Time (TBT), [[Concurrent Rendering|Concurrent Rendering]]
|
||||
- **Projects/Contexts:** [[Next.js App Router|Next.js App Router]], [[Island Architecture|Island Architecture]]
|
||||
- **Contradictions/Notes:** SSR은 클라이언트에게 완성된 HTML을 즉시 제공하여 FCP(First Contentful Paint)와 SEO를 크게 향상시키지만, JavaScript 번들이 다운로드되고 Hydration이 완료될 때까지 사용자가 페이지와 상호작용할 수 없으므로 TTI(Time to Interactive)가 오히려 지연되는 성능적 트레이드오프(Trade-off)가 존재합니다 [20, 21].
|
||||
@@ -163,3 +175,52 @@ No trade-offs available.
|
||||
|
||||
---
|
||||
*Last updated: 2026-04-25*
|
||||
|
||||
## 🤖 LLM 활용 힌트 (How to Use This Knowledge)
|
||||
|
||||
**언제 이 지식을 쓰는가:**
|
||||
- *(TODO)*
|
||||
|
||||
**언제 쓰면 안 되는가:**
|
||||
- *(TODO)*
|
||||
|
||||
## 🧪 검증 상태 (Validation)
|
||||
|
||||
- **정보 상태:** needs_review
|
||||
- **출처 신뢰도:** A
|
||||
- **검토 이유:** *(P-Reinforce Phase 1 자동 정규화. 본문 검증 필요.)*
|
||||
|
||||
## 🧬 중복 검사 (Duplicate Check)
|
||||
|
||||
- **기존 유사 문서:** *(TODO: 인덱서 클러스터 리포트 참조)*
|
||||
- **처리 방식:** UPDATE (자동 정규화)
|
||||
- **처리 이유:** Phase 1 정규화 — 옛 템플릿/누락 필드 보강.
|
||||
|
||||
## 🕓 변경 이력 (Changelog)
|
||||
|
||||
| 날짜 | 변경 내용 | 처리 방식 | 신뢰도 |
|
||||
|------|-----------|-----------|--------|
|
||||
| 2026-05-08 | P-Reinforce Phase 1 정규화 (frontmatter + 헤더 표준화) | UPDATE | A |
|
||||
|
||||
## 💻 코드 패턴 (Code Patterns)
|
||||
|
||||
**패턴 1:** *(TODO: 이 프로젝트 컨벤션 반영한 구조 스켈레톤)*
|
||||
|
||||
```text
|
||||
# TODO
|
||||
```
|
||||
|
||||
## 🤔 의사결정 기준 (Decision Criteria)
|
||||
|
||||
**선택 A를 써야 할 때:**
|
||||
- *(TODO)*
|
||||
|
||||
**선택 B를 써야 할 때:**
|
||||
- *(TODO)*
|
||||
|
||||
**기본값:**
|
||||
> *(TODO)*
|
||||
|
||||
## ❌ 안티패턴 (Anti-Patterns)
|
||||
|
||||
- **[안티패턴]:** *(TODO: 무엇을 하면 안 되는가 + 이유 + 대신 무엇을)*
|
||||
Reference in New Issue
Block a user