- React 16.5부터 새로운 DevTools profiler 플러그인의 지원이 추가됨
- 이 플러그인은 React 애플리케이션에서의 성능 병목 현상을 찾기 위해서 렌더링된 각 컴포넌트에 대한 소요 시간 정보를 수집하는 실험적인 profiler API임
Note
react-dom
16.5부터 DEV mode에서의 프로파일링을 지원함
- production profiling bundle은
react-dom/profiling
로 이용 가능함
- DevTools에 profiler를 지원하는
Profiler
탭이 존재함
Profiler
패널은 초기에 비어 있음
- 녹음 버튼을 클릭하여 프로파일링을 시작함
- 녹음을 시작하면, DevToools은 애플리케이션이 렌더링될 때마다 성능 정보를 자동적으로 수집함
- 프로파일링을 끝낼 때, 중지 버튼을 클릭함
성능 데이터 분석하기
Browsing commits
- React는 개념적으로 2개의 phase로 동작함
- render phase
- render phase는 어떤 변화(예: DOM)가 만들어져야 하는지 결정함
- render phase에서 React는
render
를 호출하고, 그 결과와 이전 render 결과를 비교함
- commit phase
- commit phase에서 React는 변화를 적용함(DOM의 경우, React는 DOM 노드를 삽입, 갱신, 제거함)
- commit phase에서 React는 또한
componentDidMount
와 componentDidUpdate
와 같은 생명주기 메서드를 호출함
- DevTools profiler는 commit에 의한 성능 정보를 그룹화함
- commit들은 profiler의 상단 막대 그래프에 나타냄
- 막대 그래프의 각 막대는 하나의 commit을 나타냄
- 푸른 막대는 현재 선택된 commit을 의미함
- 막대를 클릭하거나, 좌우 버튼을 클릭하여 다른 commit을 선택할 수 있음
- 각 막대의 색과 높이는 commit이 렌더링되는데 걸린 시간을 나타냄
- 막대가 길고 노란색에 가까울 수록 시간이 더 많이 걸렸다는 것을 의미함
Filtering commits
- profile이 길수록, 애플리케이션을 렌더링하는 시간이 오래 걸림
- 때때로 process에서 너무 많은 commit들이 있을 수 있음
- profiler는 문턱값(threshold)을 설정하여 문턱값보다 빠른 commit들을 숨길 수 있음
Flame chart
Ranked chart
- ranked chart는 단 하나의 commit을 나타냄
- 그래프에서 각 막대는 React 컴포넌트(예: App, Nav)를 나타냄
- 이 그래프는 렌더링하는데 가장 오래 걸린 컴포넌트 막대가 상단에 위치하도록 정렬됨
- 컴포넌트의 렌더링하는 데 걸리는 시간은 컴포넌트의 자식들이 렌더링하는 데 걸린 시간이 포함되어 있음
- 그래서 렌더링하는데 가강 오래 걸린 컴포넌트는 일반적으로 트리의 상단에 있음
- 그래프의 컴포넌트 막대를 클릭하여 확대할 수 있음
예) header 컴포넌트의 초기 상태는 false임
예) header 컴포넌트에 mouse를 hover하면 상태가 true로 바뀜
Suspend the selected Component
- 좌측 패널의 타이머 버튼을 클릭하면, 선택된 컴포넌트를 임시로 정지시킬 수 있음
- 단, 선택한 컴포넌트가
Suspend Container
안에 있어야 함
- 그렇지 않다면, 에러가 발생함
Inspect the matching DOM Element
- 좌측 패널의 눈 모양 버튼을 클릭하면, html 파일에서의 선택한 컴포넌트와 일치하는 DOM 엘레먼트를 보여줌
Log the Component data in Console
- 좌측 패널의 벌레 모양 버튼을 클릭하면, 선택한 컴포넌트의 데이터를 콘솔창에 출력할 수 있음
View the Source for the element
- 좌측 패널의 빈 괄호 버튼을 클릭하여, 선택한 엘리먼트의 JavaScript Source 코드를 확인할 수 있음