Dodawanie niestandardowego monitorowania na potrzeby konkretnych żądań sieciowych (aplikacje Apple i na Androida)


Performance Monitoring zbiera ślady, aby pomóc Ci monitorować skuteczność aplikacji. Ślad to raport z danymi o skuteczności zarejestrowanymi między 2 punktami w czasie w aplikacji.

Logi czasu żądań sieciowych zbierane automatycznie przez Performance Monitoring obejmują większość żądań sieciowych w Twojej aplikacji. Niektóre żądania mogą jednak nie być raportowane lub możesz używać innej biblioteki do wysyłania żądań sieciowych. W takich przypadkach możesz użyć interfejsu Performance Monitoring API do ręcznego instrumentowania niestandardowych logów czasu żądań sieciowych. Niestandardowe logi czasu żądań sieciowych są obsługiwane tylko w przypadku aplikacji na urządzenia Apple i Androida.

Domyślne dane w przypadku niestandardowego logu czasu żądań sieciowych są takie same jak w przypadku logów czasu żądań sieciowych zbieranych automatycznie przez Performance Monitoring, a mianowicie czas odpowiedzi, rozmiar ładunku odpowiedzi i żądania oraz odsetek powodzeń. Niestandardowe ślady żądań sieciowych nie obsługują dodawania niestandardowych kategorii danych.

W kodzie definiujesz początek i koniec śledzenia niestandardowego żądania sieciowego za pomocą interfejsów API udostępnianych przez pakiet SDK Performance Monitoring.

Niestandardowe logi czasu żądań sieciowych pojawiają się w Firebase konsoli obok żądań sieciowych, które Performance Monitoring rejestruje automatycznie (na karcie Żądania sieciowe w tabeli logów czasu).

Dodawanie niestandardowych logów czasu żądań sieciowych

Użyj Performance Monitoringinterfejsu HTTPMetric API (Swift | Obj-C), aby dodać niestandardowe ślady żądań sieciowych i monitorować konkretne żądania sieciowe.

Aby ręcznie instrumentować niestandardowe żądania sieciowe w Performance Monitoring, dodaj kod podobny do tego:

Swift

Uwaga: ten produkt Firebase nie jest dostępny na platformach macOS, Mac Catalyst i 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()

Objective-C

Uwaga: ten produkt Firebase nie jest dostępny na platformach macOS, Mac Catalyst i 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];
}

Ślady niestandardowych żądań sieciowych obsługują też dodawanie atrybutów niestandardowych (Swift | Obj-C), ale nie danych niestandardowych.

Dalsze kroki

  • Skonfiguruj alerty dotyczące żądań sieciowych, które pogarszają wydajność aplikacji. Możesz na przykład skonfigurować alert e-mail dla zespołu, jeśli czas odpowiedzi dla określonego wzorca adresu URL przekroczy ustawiony przez Ciebie próg.