Files
2nd/01_Archive/2026-04-20/보존 경로(Retaining Path).md

34 lines
4.1 KiB
Markdown

---
id: P-REINFORCE-AUTO-97AEC6
category: "10_Wiki/💡 Topics/AI"
confidence_score: 0.90
tags: [auto-reinforced]
last_reinforced: 2026-04-20
github_commit: "[P-Reinforce] Continuous Worker - 보존 경로(Retaining Path)"
---
# [[보존 경로(Retaining Path)|보존 경로(Retaining Path)]]
## 📌 한 줄 통찰 (The Karpathy Summary)
> 보존 경로(Retaining Path)는 메모리 누수를 조사할 때 특정 객체가 가비지 컬렉션(GC)에 의해 수거되지 않고 살아남게 만드는 참조 체인(chain of references)을 의미합니다 [1, 2]. V8 엔진은 전역 창(window) 객체나 활성 스택의 로컬 변수와 같은 루트 객체(GC Root)로부터 포인터 체인을 통해 도달 가능한 객체를 메모리에 유지해야 할 객체로 간주합니다 [3]. 개발자는 힙 스냅샷 도구나 특수 디버깅 플래그를 사용하여 이러한 보존 경로를 역추적하고 불필요한 참조를 식별하여 메모리 누수 문제를 해결할 수 있습니다 [2-4].
## 📖 구조화된 지식 (Synthesized Content)
* **보존 경로의 개념 및 역할:** 가비지 컬렉터는 루트 객체로부터 참조를 통해 도달할 수 있는 객체를 '살아있는(live)' 객체로 판단하여 수거 대상에서 제외합니다 [3, 5]. 메모리 누수가 발생했을 때, 객체가 왜 수거되지 않는지를 파악하기 위해서는 이 보존 경로를 추적하는 것이 필수적입니다 [4]. 모든 힙 스냅샷은 많은 후방(back) 참조와 루프를 포함하고 있어 하나의 객체에 여러 보존자가 존재할 수 있습니다 [5].
* **개발자 도구(DevTools)를 통한 분석:** Chrome DevTools의 Memory 패널에서 힙 스냅샷(Heap Snapshot)이나 할당 타임라인(Allocation timeline)을 통해 특정 객체를 선택하면, 'Retainers(보존자)' 섹션에서 해당 객체의 보존 트리(Retaining tree)를 확인할 수 있습니다 [1, 2, 4, 6]. 이 트리는 누수된 객체에서부터 이를 붙잡고 있는 GC 루트까지의 경로를 역순(reverse)으로 보여줍니다 [3, 7].
* **보존자 무시(Ignore retainers) 기능:** DevTools에서는 특정 보존자를 마우스 우클릭하여 "Ignore this retainer"를 선택함으로써 해당 참조를 숨길 수 있습니다 [8]. 이를 통해 코드를 직접 수정하여 참조를 제거한 뒤 스냅샷을 다시 찍는 번거로운 과정 없이, 다른 객체가 해당 객체를 계속 보존하고 있는지 쉽게 파악할 수 있습니다 [8].
* **로우레벨(Low-level) 추적:** 매우 복잡한 누수의 경우 V8의 내부 함수인 `%DebugTrackRetainingPath(object)`를 사용할 수 있습니다 [3, 9]. `--allow-natives-syntax``--track-retaining-path` 런타임 플래그와 함께 실행하면, GC가 발생할 때마다 보존 경로 내 모든 내부 객체의 16진수 주소와 타입을 출력하여 DevTools UI의 추상화를 우회하는 세부적인 로그를 얻을 수 있습니다 [3, 9]. gdb나 lldb와 같은 디버거 세션 중에도 `isolate->heap()->PrintRetainingPath(HeapObject*)` 명령을 통해 객체의 보존 경로를 출력할 수 있습니다 [10].
## ⚠️ 모순 및 업데이트 (Contradictions & RL Update)
- **과거 데이터와의 충돌:** 자동화 엔진에 의해 매핑된 지식으로, 추후 정밀 검증 필요.
- **정책 변화:** AI 분야의 자동 자산화 수행.
## 🔗 지식 연결 (Graph)
- **Related Topics:** [[Garbage Collection|Garbage Collection]], [[Heap Snapshot|Heap Snapshot]], [[GC Root|GC Root]], [[Memory Leak|Memory Leak]]
- **Projects/Contexts:** [[V8 Engine|V8 Engine]], [[Chrome DevTools|Chrome DevTools]], [[Node.js Memory Management|Node.js Memory Management]]
- **Contradictions/Notes:** 소스 내에 상충되는 내용은 없습니다. 보존 경로는 개념적으로 루트(Root) 객체로부터 시작되는 포인터의 체인이지만, DevTools 등의 분석 도구에서는 누수된 객체에서 루트로 올라가는 역순(reverse)으로 경로를 시각화하여 디버깅을 돕습니다 [3].
---
*Last updated: 2026-04-19*
- Raw Source: 00_Raw/2026-04-20/보존 경로(Retaining Path).md
---