id, title, category, status, source_trust_level, verification_status, created_at, updated_at, tags, tech_stack, applied_in, aliases
| id |
title |
category |
status |
source_trust_level |
verification_status |
created_at |
updated_at |
tags |
tech_stack |
applied_in |
aliases |
| devops-build-performance |
Build Performance — 빌드 시간 측정과 단축 |
Coding |
draft |
B |
conceptual |
2026-05-09 |
2026-05-09 |
| devops |
| build |
| performance |
| vite |
| esbuild |
| vibe-coding |
|
| language |
applicable_to |
| Vite / esbuild / SWC / Webpack |
|
|
|
| bundler |
| esbuild |
| swc |
| tsc |
| profile |
|
Build Performance
"왜 느린지" 측정 안 하고 추측 최적화 = 시간 낭비. profile → 가장 큰 단일 원인 → 도구 교체 또는 캐시. 2026 권장: Vite (esbuild + Rollup), Turbopack (Webpack 후속), SWC, esbuild.
📖 핵심 개념
- Bundle: 여러 파일 → 하나/적은 수.
- Compile: TS/JSX → JS. tsc 느림, swc/esbuild 100x.
- Type check: tsc --noEmit 별도 — bundle 과 분리.
- Cache: incremental build, persistent.
💻 코드 패턴
Vite 기본 (가장 빠른 dev)
TypeScript — tsc 분리
tsc incremental
Bundle 분석
큰 dependency 발견 → tree-shake / 동적 import / 교체.
Profile build
Esbuild 직접 (작은 프로젝트, 매우 빠름)
대형 프로젝트도 1초.
Cache — Turbo / Nx
Parallel CI
🤔 의사결정 기준
| 작업 |
도구 |
| Web dev |
Vite + SWC |
| Web prod bundle |
Vite (Rollup 내장) 또는 Turbopack |
| Node.js single binary |
esbuild bundle + node executable |
| TS typecheck |
tsc --noEmit (별도) |
| Test runner |
Vitest (Vite 호환) 또는 Jest with SWC |
| Linter |
Biome (Rust, fast) 또는 ESLint + SWC |
❌ 안티패턴
- build = bundle + typecheck + test 한 명령: 한 fail 모두 다시. 분리 + 병렬.
- tsc 로 bundle: 느림 + tree-shake 약함.
- dev 와 prod 다른 bundler: 일관성 깨짐.
- 모든 의존성 단일 chunk: 큰 first paint. manual chunks.
- source map prod 에 inline: 번들 크기 폭발 + 비밀 노출. external + Sentry upload.
- node_modules cache 안 함 in CI: 매번 npm install 1분+.
- measure 없이 추측 최적화: 의미 없는 변경.
🤖 LLM 활용 힌트
- "Vite + SWC + Vitest + Biome" 가 2026 빠른 스택.
- typecheck 는 항상 분리 / 병렬.
🔗 관련 문서