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 personalizzata della richiesta di rete 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 Monitoring API HttpMetric per aggiungere tracce delle 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:

Kotlin

val url = URL("https://www.google.com")
val metric = Firebase.performance.newHttpMetric(
    "https://www.google.com",
    FirebasePerformance.HttpMethod.GET,
)
metric.trace {
    val conn = url.openConnection() as HttpURLConnection
    conn.doOutput = true
    conn.setRequestProperty("Content-Type", "application/json")
    try {
        val outputStream = DataOutputStream(conn.outputStream)
        outputStream.write(data)
    } catch (ignored: IOException) {
    }

    // Set HttpMetric attributes
    setRequestPayloadSize(data.size.toLong())
    setHttpResponseCode(conn.responseCode)

    printStreamContent(conn.inputStream)

    conn.disconnect()
}

Java

HttpMetric metric =
        FirebasePerformance.getInstance().newHttpMetric("https://www.google.com",
                FirebasePerformance.HttpMethod.GET);
final URL url = new URL("https://www.google.com");
metric.start();
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setDoOutput(true);
conn.setRequestProperty("Content-Type", "application/json");
try {
    DataOutputStream outputStream = new DataOutputStream(conn.getOutputStream());
    outputStream.write(data);
} catch (IOException ignored) {
}
metric.setRequestPayloadSize(data.length);
metric.setHttpResponseCode(conn.getResponseCode());
printStreamContent(conn.getInputStream());

conn.disconnect();
metric.stop();

Le tracce delle richieste di rete personalizzate supportano anche l'aggiunta di attributi personalizzati, 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.