- React 16.5부터 새로운 DevTools profiler 플러그인의 지원이 추가됨
- 이 플러그인은 React 애플리케이션에서의 성능 병목 현상을 찾기 위해서 렌더링된 각 컴포넌트에 대한 소요 시간 정보를 수집하는 실험적인 profiler API임
Note
react-dom
16.5부터 DEV mode에서의 프로파일링을 지원함
- production profiling bundle은
react-dom/profiling
로 이용 가능함
data:image/s3,"s3://crabby-images/d5837/d5837483fa5b9eb691619a8dd40049d6e5bc70ac" alt=""
- 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
와 같은 생명주기 메서드를 호출함
data:image/s3,"s3://crabby-images/96b84/96b844042fa3f0fec8dc892485f0ad09b7f840e5" alt=""
- DevTools profiler는 commit에 의한 성능 정보를 그룹화함
- commit들은 profiler의 상단 막대 그래프에 나타냄
- 막대 그래프의 각 막대는 하나의 commit을 나타냄
- 푸른 막대는 현재 선택된 commit을 의미함
- 막대를 클릭하거나, 좌우 버튼을 클릭하여 다른 commit을 선택할 수 있음
- 각 막대의 색과 높이는 commit이 렌더링되는데 걸린 시간을 나타냄
- 막대가 길고 노란색에 가까울 수록 시간이 더 많이 걸렸다는 것을 의미함
Filtering commits
data:image/s3,"s3://crabby-images/d9574/d957498540dea34d4240b96a4dc15a29d28b0b5c" alt=""
- profile이 길수록, 애플리케이션을 렌더링하는 시간이 오래 걸림
- 때때로 process에서 너무 많은 commit들이 있을 수 있음
- profiler는 문턱값(threshold)을 설정하여 문턱값보다 빠른 commit들을 숨길 수 있음
Flame chart
data:image/s3,"s3://crabby-images/1a18d/1a18d8884a1b9b095f19e707a1ca4b23c0304706" alt=""
Ranked chart
data:image/s3,"s3://crabby-images/67b9d/67b9dc434856813d2d2c786816e65b5251b2e142" alt=""
- ranked chart는 단 하나의 commit을 나타냄
- 그래프에서 각 막대는 React 컴포넌트(예: App, Nav)를 나타냄
- 이 그래프는 렌더링하는데 가장 오래 걸린 컴포넌트 막대가 상단에 위치하도록 정렬됨
- 컴포넌트의 렌더링하는 데 걸리는 시간은 컴포넌트의 자식들이 렌더링하는 데 걸린 시간이 포함되어 있음
- 그래서 렌더링하는데 가강 오래 걸린 컴포넌트는 일반적으로 트리의 상단에 있음
- 그래프의 컴포넌트 막대를 클릭하여 확대할 수 있음
data:image/s3,"s3://crabby-images/20e83/20e8324682be2b3db25922e2498a574337794048" alt=""
예) header 컴포넌트의 초기 상태는 false임
data:image/s3,"s3://crabby-images/d089f/d089fd7c7c9f238229d8126e1535bdedd1ddbeb1" alt=""
예) header 컴포넌트에 mouse를 hover하면 상태가 true로 바뀜
data:image/s3,"s3://crabby-images/c4ae5/c4ae51d2e8dda52348809e41cc340246a5b1e2cc" alt=""
Suspend the selected Component
data:image/s3,"s3://crabby-images/d706d/d706d7def5b95758bd1eb2df7f282dd6c6f7f603" alt=""
- 좌측 패널의 타이머 버튼을 클릭하면, 선택된 컴포넌트를 임시로 정지시킬 수 있음
- 단, 선택한 컴포넌트가
Suspend Container
안에 있어야 함
- 그렇지 않다면, 에러가 발생함
data:image/s3,"s3://crabby-images/0d727/0d72709775e3cdaecb7655f310c77949dd5ce5d7" alt=""
Inspect the matching DOM Element
data:image/s3,"s3://crabby-images/63a7b/63a7bf4ba28a082312d1275c718f0d6b11f0f6b0" alt=""
- 좌측 패널의 눈 모양 버튼을 클릭하면, html 파일에서의 선택한 컴포넌트와 일치하는 DOM 엘레먼트를 보여줌
data:image/s3,"s3://crabby-images/2e06c/2e06ca00b97267a7a6f65c257d45b5be7b237445" alt=""
Log the Component data in Console
data:image/s3,"s3://crabby-images/f415d/f415da545ea1a435bb885601758589f0884f1a95" alt=""
- 좌측 패널의 벌레 모양 버튼을 클릭하면, 선택한 컴포넌트의 데이터를 콘솔창에 출력할 수 있음
data:image/s3,"s3://crabby-images/4fece/4fecef50dbb9e4804eb098f500e6f84114e0ef13" alt=""
View the Source for the element
data:image/s3,"s3://crabby-images/cfab2/cfab2f2f4ce67ca46121e54fa749d751a62725e3" alt=""
- 좌측 패널의 빈 괄호 버튼을 클릭하여, 선택한 엘리먼트의 JavaScript Source 코드를 확인할 수 있음
data:image/s3,"s3://crabby-images/f4bfb/f4bfb2e206b1d1293c100f37438e136745ce412a" alt=""