3.3 KiB
3.3 KiB
GPU 가속 및 컴포지팅
📌 brief Summary
GPU 가속 및 컴포지팅은 브라우저의 메인 스레드에서 처리하던 애니메이션 작업을 기기의 GPU(그래픽 처리 장치)로 위임하여 웹 성능을 크게 향상시키는 기술입니다 [1]. 이 기법을 사용하면 비용이 많이 드는 브라우저의 레이아웃(Reflow) 및 페인트(Repaint) 단계를 건너뛰고, 오직 컴포지트(Composite) 단계만을 실행하여 렌더링 부담을 줄일 수 있습니다 [2]. 특히 모바일 기기나 저사양 환경에서도 초당 60프레임(60 FPS)의 매끄러운 애니메이션을 달성하는 데 핵심적인 역할을 합니다 [2-4].
📖 Core 단락
- 픽셀 파이프라인과 컴포지트 단계: DOM 요소가 변경될 때 브라우저는 '스타일 재계산 -> 레이아웃(Reflow) -> 페인트(Repaint) -> 컴포지트(Composite)'로 이어지는 픽셀 파이프라인을 실행합니다 [5]. 애니메이션 성능을 극한으로 끌어올리기 위해서는 전체 파이프라인을 다시 거치지 않고, 마지막 컴포지트 단계만을 유발하는 속성을 사용하는 것이 중요합니다 [2].
- GPU 가속을 유발하는 속성: 브라우저가 특정 애니메이션을 자동으로 GPU로 보내도록 만들 수 있습니다 [1]. 대표적으로
transform과opacity속성이 이를 지원하며, 리플로우나 리페인트 없이 GPU 가속을 통해 애니메이션을 처리합니다 [2, 6, 7]. 추가로transform: translateZ()나rotate3d()같은 3D 변환,position: fixed, 그리고will-change속성이 적용된 요소나<video>,<canvas>,<iframe>요소 등도 자체적인 레이어에서 렌더링되어 컴포지팅의 이점을 얻습니다 [3]. - 사용 시 주의사항: 모든 속성이 가속을 통해 이점을 얻는 것은 아닙니다.
box-shadow,filter,border-radius와 같은 속성들은 애니메이션 시 컴포지팅 레이어나 블렌딩 과정에서 추가적인 리소스를 요구하여 오히려 애니메이션을 느리게 만들 수 있습니다 [6]. 또한will-change속성은 브라우저가 변경 사항을 미리 최적화하도록 돕지만, 너무 많은 요소에 남용할 경우 도리어 성능을 저하시킬 수 있습니다 [8]. - 성능 프로파일링 및 디버깅: CSS 애니메이션이 올바르게 최적화되었는지 확인하려면 Chrome DevTools를 활용할 수 있습니다. 특히 Layer Profiler를 사용하면 어떤 요소가 복합 레이어(Composite layer)에서 렌더링되고 있는지 식별하여 성능 병목 현상을 파악할 수 있습니다 [9].
🔗 Knowledge Connections
- Related Topics: CSS 애니메이션 성능 최적화, Reflow와 Repaint (리플로우와 리페인트), transform 및 opacity 속성, will-change 속성
- Projects/Contexts: 모바일 우선 및 저사양 기기를 고려한 웹 성능 최적화, 60 FPS의 부드러운 상호작용 및 애니메이션 구현
- Contradictions/Notes: 컴포지팅은 애니메이션 성능 최적화의 핵심이지만,
box-shadow나filter등의 속성을 포함한 애니메이션은 무거운 렌더링 과정을 유발해 오히려 성능 저하를 초래할 수 있으므로 주의해야 합니다 [6].
Last updated: 2026-04-26