Catch up on everthing we announced at this year's Firebase Summit. Learn more

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

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

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

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

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

Следы запроса Пользовательских сетей отображаются в консоли Firebase наряду с сетевыми запросами , которые Мониторинг автоматически собираемой Производительность (в сети запрашивает подвкладку таблицы следов).

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

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

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

Быстрый

Примечание: Этот продукт 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 ) , но не пользовательские метрики.