Aggiungere un monitoraggio personalizzato per richieste di rete specifiche (app Apple e Android)


Performance Monitoring raccoglie le tracce per aiutarti a monitorare il rendimento della tua app. Una traccia è un report dei dati sul rendimento acquisiti tra due istanti nella tua app.

Le tracce delle richieste di rete raccolte automaticamente da Performance Monitoring includono la maggior parte delle richieste di rete per la tua app. Tuttavia, alcune richieste potrebbero non essere registrate o potresti utilizzare una libreria diversa per effettuare richieste di rete. In questi casi, puoi utilizzare l'API Performance Monitoring per eseguire manualmente l'instrumentazione di tracce delle richieste di rete personalizzate. Le tracce delle richieste di rete personalizzate sono supportate solo per le app Apple e Android.

Le metriche predefinite per una traccia della richiesta di rete personalizzata sono le stesse di quelle per le tracce delle richieste di rete raccolte automaticamente da Performance Monitoring, in particolare il tempo di risposta, le dimensioni del payload di risposta e richiesta e la percentuale di successo. Le tracce delle richieste di rete personalizzate non supportano l'aggiunta di metriche personalizzate.

Nel codice, definisci l'inizio e la fine di una traccia della richiesta di rete personalizzata utilizzando le API fornite dall'SDK Performance Monitoring.

Le tracce delle richieste di rete personalizzate vengono visualizzate nella console Firebase insieme alle richieste di rete acquisite automaticamente da Performance Monitoring (nella sottoscheda Richieste di rete della tabella delle tracce).

Aggiungere tracce di richieste di rete personalizzate

Utilizza l'Performance MonitoringAPI HTTPMetric (Swift | Obj-C) per aggiungere tracce di richieste di rete personalizzate per monitorare richieste di rete specifiche.

Per eseguire manualmente l'instrumentazione delle richieste di rete personalizzate in Performance Monitoring, aggiungi codice simile al seguente:

Swift

Nota:questo prodotto Firebase non è disponibile sui target macOS, Mac Catalyst e 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

Nota:questo prodotto Firebase non è disponibile sui target macOS, Mac Catalyst e 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];
}

Le tracce delle richieste di rete personalizzate supportano anche l'aggiunta di attributi personalizzati (Swift | Obj-C), ma non di metriche personalizzate.

Passaggi successivi

  • Configura gli avvisi per le richieste di rete che stanno peggiorando il rendimento della tua app. Ad esempio, puoi configurare un avviso via email per il tuo team se il tempo di risposta per un pattern URL specifico supera una soglia impostata.