HTTP/S 네트워크 요청 성능 데이터에 대해 알아보기(모든 앱)

성능 모니터링은 추적 을 사용하여 앱에서 모니터링되는 프로세스에 대한 데이터를 수집합니다. 추적은 앱의 두 시점 사이에 캡처된 데이터가 포함된 보고서입니다.

모든 앱 유형에 대해 Performance Monitoring은 HTTP/S 네트워크 요청 추적 이라고 하는 앱에서 발행한 각 네트워크 요청에 대한 추적을 자동으로 수집합니다. 이러한 추적은 앱이 서비스 엔드포인트에 대한 요청을 발행한 시점과 해당 엔드포인트의 응답이 완료된 시점 사이의 시간에 대한 메트릭을 수집합니다. 앱이 요청하는 모든 엔드포인트에 대해 Performance Monitoring은 다음과 같은 몇 가지 측정항목을 캡처합니다.

  • 응답 시간 — 요청이 이루어진 시점과 응답이 완전히 수신된 시점 사이의 시간

  • 응답 페이로드 크기 — 앱에서 다운로드한 네트워크 페이로드의 바이트 크기

  • 요청 페이로드 크기 — 앱에서 업로드한 네트워크 페이로드의 바이트 크기

  • 성공률 — 총 응답 대비 성공한 응답의 백분율(100 - 399 범위의 응답 코드)

성능 대시보드 하단에 있는 추적 테이블의 네트워크 요청 하위 탭에서 이러한 추적의 데이터를 볼 수 있습니다(이 페이지 뒷부분에서 콘솔 사용에 대해 자세히 알아보기).

성능 모니터링은 다음 네트워킹 라이브러리를 사용하는 네트워크 요청에 대한 메트릭을 자동으로 수집합니다.

빠른

  • URL세션
  • URL연결

오브젝티브-C

  • NSURL세션
  • NSURL연결

네트워크 요청 데이터 집계 사용자 지정

네트워크 요청에 대한 즉시 사용 가능한 도구 및 데이터 집계 외에도 Performance Monitoring은 다음 옵션도 지원합니다.

  • 네트워크 요청 추적 수동 계측: 즉시 사용 가능한 모니터링에는 앱에 대한 대부분의 네트워크 요청이 포함됩니다. 그러나 일부 요청은 보고되지 않거나 다른 라이브러리를 사용하여 네트워크 요청을 할 수 있습니다. 이러한 경우 성능 모니터링 API를 사용하여 사용자 지정 네트워크 요청 추적 을 수동으로 계측할 수 있습니다.
  • 맞춤 URL 패턴에서 데이터 집계: Firebase에서 파생된 자동 URL 패턴 일치로 캡처하지 않는 특정 URL이 있는 경우 맞춤 URL 패턴 을 만들어 시간이 지남에 따라 특정 URL 집합을 모니터링할 수 있습니다.
  • 성공률 계산 방법 사용자 지정: 특정 API 엔드포인트에 대해 오류 코드가 예상되거나 앱에서 이미 처리되는 경우가 있습니다. 이러한 경우 성공률을 계산하는 방법을 구성하고 앱의 네트워크 호출 성공률을 보다 정확하게 모니터링할 수 있습니다.

URL 패턴에 따른 데이터 집계

Firebase 성능 모니터링은 유사한 네트워크 요청에 대한 데이터를 자동으로 집계하여 네트워크 요청 성능의 추세를 이해하는 데 도움이 됩니다.

각 요청에 대해 Firebase는 네트워크 요청의 URL이 URL 패턴과 일치하는지 확인합니다. 요청 URL이 URL 패턴과 일치하는 경우 Firebase는 URL 패턴 아래에 요청 데이터를 자동으로 집계합니다. Firebase는 Firebase 콘솔의 성능 대시보드 에 있는 네트워크 탭에 URL 패턴과 집계 데이터를 표시합니다.

URL 패턴이란 무엇입니까?

URL 패턴에는 도메인과 URL 경로와 일치할 수 있는 패턴이 포함됩니다(예: example.com/*/animals/** ).

  • URL 패턴에는 다음과 같은 경로 세그먼트가 포함될 수 있습니다.

    • 일반 텍스트 — 정확한 문자열과 일치
    • * — 단일 경로 세그먼트의 모든 문자열과 일치
    • ** — 임의의 경로 접미사와 일치
  • URL 패턴은 다음 중 하나일 수 있습니다.

예: 다음 URL 요청은 URL 패턴 example.com/*/animals/** 와 일치할 수 있습니다.

  • example.com/singapore/animals
  • example.com/australia/animals/spiders
  • example.com/australia/animals/marsupials/koala.png

URL 패턴의 도메인은 첫 번째 세그먼트로 * 를 포함할 수도 있습니다(예: *.example.com/*/fruits/** ).

Firebase는 각 요청을 하나의 URL 패턴에만 매핑합니다. 맞춤 URL 패턴 을 구성한 경우 Firebase는 먼저 요청 URL을 해당 패턴과 일치시키려고 시도합니다. Firebase에서 일치하는 맞춤 URL 패턴을 찾지 못하면 요청 URL을 가장 대표적인 자동 URL 패턴 과 일치시킵니다. 다음 섹션에서 자동 및 맞춤 URL 패턴에 대해 자세히 알아보세요.

자동 URL 패턴

사용자가 구성하지 않으면 Performance Monitoring은 앱의 요청을 자동 URL 패턴 과 일치시켜 앱의 최신 사용 동작을 반영하려고 시도합니다.

자동 URL 패턴 일치는 어떻게 작동합니까?

Firebase는 각 요청을 앱에서 보낸 요청에서 파생된 가장 대표적인 자동 URL 패턴과 일치시킵니다. 그러나 Firebase는 먼저 구성된 맞춤 URL 패턴 에 요청 URL을 일치시키려고 시도합니다.

다음은 Firebase가 앱의 가장 대표적인 자동 URL 패턴에 요청을 일치시키려고 시도하는 방법에 대한 기본 예입니다.

  1. 앱은 다음과 같은 URL에 많은 요청을 보냅니다.

    • example.com/germany/animals/bears
    • example.com/germany/animals/birds
    • example.com/germany/cars

    Firebase는 example.com/germany/** 가 앱의 일반적인 요청 패턴이라고 판단하고 이를 프로젝트에 자동 URL 패턴으로 추가합니다.

    이 URL 패턴에 대한 새로운 일치 요청의 경우 Firebase는 자동 URL 패턴 example.com/germany/** 아래에 요청 데이터를 집계합니다.

  2. 일주일 후 앱 요청의 대부분은 example.com/germany/animals/bearsexample.com/germany/animals/birds 입니다. 따라서 Firebase는 example.com/germany/animals/** 의 보다 대표적인 URL 패턴을 파생합니다.

    이 새 URL 패턴에 대한 새로운 일치 요청의 경우 Firebase는 새 URL 패턴 에서만 요청 데이터를 집계합니다. Firebase는 example.com/germany/cars 아래의 example.com/germany/** 에 대한 요청에 대한 데이터를 계속 집계합니다.

  3. 그러나 앞으로 몇 주 동안 example.com/germany/animals/bearsexample.com/germany/animals/birds 에 대한 앱의 요청이 상당히 감소합니다. Firebase는 example.com/germany/animals/** 가 앱의 최신 사용 동작을 나타내지 않는다고 판단하므로 Firebase는 이 두 요청을 example.com/germany/** 에 다시 일치시키기 시작합니다.

    Firebase는 더 이상 가장 대표적인 자동 URL 패턴이 아니기 때문에 example.com/germany/animals/** 에서 추가 요청 데이터를 집계하지 않습니다.

자동 URL 패턴 일치는 동적이므로 다음 사항에 유의하십시오.

  • 이전 요청의 일치 및 집계 데이터는 새 URL 패턴의 영향을 받지 않습니다. Firebase는 요청 데이터를 소급하여 다시 집계하지 않습니다.

  • 향후 요청만 새 URL 패턴의 영향을 받습니다. Firebase는 각각의 요청을 가장 대표적인 자동 URL 패턴에 매핑합니다. 그러나 Firebase는 먼저 구성된 맞춤 URL 패턴 에 요청 URL을 일치시키려고 시도합니다.

자동 URL 패턴 및 해당 데이터 보기

Firebase는 Firebase 콘솔의 성능 대시보드 하단에 있는 추적 테이블의 네트워크 요청 하위 탭에 모든 URL 패턴과 집계된 데이터를 표시합니다.

분류되지 않은 레이블이 있는 URL 패턴을 볼 수 있습니다. Firebase가 더 이상 특정 URL 패턴과 일치하지 않는 요청에 대한 데이터를 집계할 수 있는 "광범위한" 자동 URL 패턴입니다.

URL 패턴으로 집계된 데이터의 데이터 보존 기간 이 종료되면 Firebase는 URL 패턴에서 해당 데이터를 삭제합니다. 자동 URL 패턴으로 집계된 모든 데이터가 만료되면 Firebase는 Firebase 콘솔에서 해당 URL 패턴을 삭제합니다.

맞춤 URL 패턴

Firebase가 파생된 자동 URL 패턴 일치 로 캡처하지 않는 특정 URL 패턴을 모니터링하는 맞춤 URL 패턴 을 만들 수 있습니다. 예를 들어 사용자 지정 URL 패턴을 사용하여 특정 URL 문제를 해결하거나 시간 경과에 따른 특정 URL 집합을 모니터링할 수 있습니다.

자세히 알아보려면 맞춤 URL 패턴 만들기 를 방문하세요.

성능 데이터 추적, 보기 및 필터링

실시간 성능 데이터를 보려면 앱이 실시간 데이터 처리와 호환되는 Performance Monitoring SDK 버전을 사용하는지 확인하십시오. 실시간 성능 데이터에 대해 자세히 알아보세요 .

대시보드에서 특정 측정항목 추적

주요 메트릭의 추세를 알아보려면 성능 대시보드 상단의 메트릭 보드에 추가하십시오. 주간 변경 사항을 확인하여 회귀를 빠르게 식별하거나 코드의 최근 변경 사항으로 인해 성능이 향상되고 있는지 확인할 수 있습니다.

Firebase Performance Monitoring 대시보드의 측정항목 보드 이미지

메트릭 보드에 메트릭을 추가하려면 다음 단계를 따르세요.

  1. Firebase 콘솔에서 성능 대시보드 로 이동합니다.
  2. 빈 메트릭 카드를 클릭한 다음 보드에 추가할 기존 메트릭을 선택합니다.
  3. 추가 옵션(예: 메트릭 교체 또는 제거)을 보려면 채워진 메트릭 카드에서 를 클릭하세요.

메트릭 보드는 시간 경과에 따라 수집된 메트릭 데이터를 그래픽 형식과 숫자 백분율 변경으로 표시합니다.

대시보드 사용에 대해 자세히 알아보세요.

추적 및 해당 데이터 보기

추적을 보려면 Firebase 콘솔의 성능 대시보드 로 이동하여 추적 표까지 아래로 스크롤한 다음 해당 하위 탭을 클릭합니다. 표에는 각 추적에 대한 몇 가지 상위 메트릭이 표시되며 특정 메트릭에 대한 백분율 변경을 기준으로 목록을 정렬할 수도 있습니다.

성능 모니터링은 측정항목 변경 사항을 강조 표시하는 Firebase 콘솔의 문제 해결 페이지를 제공하므로 앱과 사용자에 대한 성능 문제의 영향을 쉽고 빠르게 해결하고 최소화할 수 있습니다. 예를 들어 다음 시나리오에서 잠재적인 성능 문제에 대해 알아볼 때 문제 해결 페이지를 사용할 수 있습니다.

  • 대시보드에서 관련 메트릭을 선택하면 큰 변화가 있음을 알 수 있습니다.
  • 트레이스 테이블에서 가장 큰 델타를 맨 위에 표시하도록 정렬하면 상당한 비율 변화를 볼 수 있습니다.
  • 성능 문제를 알리는 이메일 알림을 받습니다.

다음과 같은 방법으로 문제 해결 페이지에 액세스할 수 있습니다.

  • 메트릭 대시보드에서 메트릭 세부 정보 보기 버튼을 클릭합니다.
  • 측정항목 카드에서 => 세부정보 보기 를 선택합니다. 문제 해결 페이지에는 선택한 측정항목에 대한 정보가 표시됩니다.
  • 추적 테이블에서 해당 추적과 연결된 행의 추적 이름 또는 메트릭 값을 클릭합니다.
  • 이메일 알림에서 지금 조사 를 클릭합니다.

추적 테이블에서 추적 이름을 클릭하면 관심 있는 메트릭으로 드릴다운할 수 있습니다. 필터 버튼을 클릭하여 속성별로 데이터를 필터링합니다. 예를 들면 다음과 같습니다.

속성별로 필터링되는 Firebase Performance Monitoring 데이터의 이미지
  • 앱 버전 별로 필터링하여 과거 릴리스 또는 최신 릴리스에 대한 데이터 보기
  • 기기 별로 필터링하여 구형 기기에서 앱을 처리하는 방법 알아보기
  • 국가 별로 필터링하여 데이터베이스 위치가 특정 지역에 영향을 미치지 않도록 합니다.

추적 데이터 보기 에 대해 자세히 알아보세요.

다음 단계

  • 속성을 사용하여 성능 데이터를 검사하는 방법에 대해 자세히 알아보세요.

  • Firebase 콘솔에서 성능 문제를 추적 하는 방법에 대해 자세히 알아보세요.

  • 앱의 성능을 저하시키는 네트워크 요청에 대한 경고를 설정합니다 . 예를 들어 특정 URL 패턴에 대한 응답 시간 이 설정한 임계값을 초과하는 경우 팀에 대한 이메일 알림을 구성할 수 있습니다.

  • 동일한 세션 동안 수집된 다른 추적의 타임라인 컨텍스트에서 특정 추적을 볼 수 있는 사용자 세션 에 대한 자세한 보고서를 봅니다.