Добавьте настраиваемый мониторинг для определенных сетевых запросов (приложения Apple и Android).


Performance Monitoring собирает трассировки , чтобы помочь вам отслеживать производительность вашего приложения. Трассировка — это отчет о данных производительности, собранных между двумя моментами времени в вашем приложении.

Трассировки сетевых запросов, автоматически собираемые с помощью Performance Monitoring включают большинство сетевых запросов для вашего приложения. Однако о некоторых запросах может не сообщаться, или вы можете использовать другую библиотеку для выполнения сетевых запросов. В этих случаях вы можете использовать API Performance Monitoring для ручного инструментирования трассировки пользовательских сетевых запросов . Пользовательские трассировки сетевых запросов поддерживаются только для приложений Apple и Android.

Метрики по умолчанию для пользовательской трассировки сетевых запросов такие же, как и для трассировок сетевых запросов, автоматически собираемых с помощью Performance Monitoring , а именно: время ответа, размер полезной нагрузки ответа и запроса, а также уровень успеха. Пользовательские трассировки сетевых запросов не поддерживают добавление пользовательских метрик.

В своем коде вы определяете начало и конец пользовательской трассировки сетевых запросов с помощью API, предоставляемых пакетом SDK Performance Monitoring .

Пользовательские трассировки сетевых запросов отображаются в консоли Firebase вместе с сетевыми запросами, которые Performance Monitoring фиксирует автоматически (на подвкладке «Сетевые запросы» таблицы трассировок).

Добавить пользовательские трассировки сетевых запросов

Используйте API-интерфейс Performance Monitoring HTTPMetric ( Swift | Obj-C ), чтобы добавить пользовательские трассировки сетевых запросов для мониторинга определенных сетевых запросов.

Чтобы вручную инструментировать пользовательские сетевые запросы в Performance Monitoring , добавьте код, аналогичный следующему:

Быстрый

Примечание. Этот продукт Firebase недоступен для macOS, Mac Catalyst и watchOS.
guard let metric = HTTPMetric(url: "https://www.google.com", httpMethod: .get) else { return }

metric.start()
guard let url = URL(string: "https://www.google.com") else { return }
let request: URLRequest = URLRequest(url:url)
let session = URLSession(configuration: .default)
let dataTask = session.dataTask(with: request) { (urlData, response, error) in
        if let httpResponse = response as? HTTPURLResponse {
         metric.responseCode = httpResponse.statusCode
        }
        metric.stop()
}
dataTask.resume()

Цель-C

Примечание. Этот продукт Firebase недоступен для macOS, Mac Catalyst и watchOS.
@property (nonatomic) FIRHTTPMetric *metric;

- (void)beginManualNetworkInstrumentation {
  self.metric =
      [[FIRHttpMetric alloc] initWithURL:[NSURL URLWithString:@"https://www.google.com"]
                              HTTPMethod:FIRHTTPMethodGET];

  [self.metric start];

  NSURLRequest *request =
      [NSURLRequest requestWithURL:[NSURL URLWithString:@"https://www.google.com"]];
  NSURLConnection *connection = [[NSURLConnection alloc] initWithRequest:request
                                                                delegate:self];
  [connection resume];
}

- (void)connection:(NSURLConnection *)connection
    didReceiveResponse:(NSURLResponse *) response {
  NSHTTPURLResponse* httpResponse = (NSHTTPURLResponse*)response
  self.metric.responseCode = httpResponse.statusCode;
  [self.metric stop];
}

Пользовательские трассировки сетевых запросов также поддерживают добавление пользовательских атрибутов ( Swift | Obj-C ), но не пользовательских метрик.

Следующие шаги

  • Настройте оповещения о сетевых запросах, которые снижают производительность вашего приложения. Например, вы можете настроить оповещение по электронной почте для своей команды, если время ответа для определенного шаблона URL-адреса превышает установленный вами порог.