Benutzerdefiniertes Monitoring für bestimmte Netzwerkanfragen (Apple- und Android-Apps) hinzufügen


Performance Monitoring erfasst Traces, mit denen Sie die Leistung Ihrer App im Blick behalten können. Ein Trace ist ein Bericht mit Leistungsdaten, die zwischen zwei Zeitpunkten in Ihrer App erfasst wurden.

Die von Performance Monitoring automatisch erfasste Traces von Netzwerkanfragen die meisten Netzwerkanfragen für Ihre App enthalten. Einige Anfragen sind jedoch möglicherweise nicht gemeldet wurden, oder Sie verwenden für Netzwerkanfragen eine andere Bibliothek. In diesen können Sie mit der Performance Monitoring API manuell instrumentieren benutzerdefinierte Netzwerkanfrage-Traces. Benutzerdefinierte Netzwerkanfrage-Traces sind nur Apple- und Android-Apps unterstützt werden.

Die Standardmesswerte für eine benutzerdefinierte Netzwerkanfrage-Analyse sind dieselben wie für die von Performance Monitoring automatisch erfassten Netzwerkanfrage-Analysen, insbesondere Antwortzeit, Nutzlastgröße von Antwort und Anfrage sowie Erfolgsquote. Benutzerdefiniert Netzwerkanfrage-Traces unterstützen das Hinzufügen benutzerdefinierter Messwerte nicht.

In Ihrem Code definieren Sie den Anfang und das Ende einer benutzerdefinierten Netzwerkanfrage Trace mithilfe der vom Performance Monitoring SDK bereitgestellten APIs.

Benutzerdefinierte Netzwerkanfrage-Traces werden in der Firebase-Konsole neben den automatisch erfassten Netzwerkanfragen von Performance Monitoring angezeigt (auf dem Untertab Netzwerkanfragen der Traces-Tabelle).

Benutzerdefinierte Netzwerkanfrage-Traces hinzufügen

Performance Monitoring verwenden HttpMetric-API um benutzerdefinierte Traces für Netzwerkanfragen hinzuzufügen, um bestimmte Netzwerkanfragen zu überwachen.

Wenn Sie benutzerdefinierte Netzwerkanfragen in Performance Monitoring manuell instrumentieren möchten, fügen Sie Code ähnlich dem folgenden hinzu:

Kotlin+KTX

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();

Bei benutzerdefinierten Traces von Netzwerkanfragen wird auch das Hinzufügen unterstützt benutzerdefinierte Attribute nicht jedoch benutzerdefinierte Messwerte.

Nächste Schritte

  • Richten Sie Benachrichtigungen für Netzwerkanfragen ein, die die Leistung Ihrer App beeinträchtigen. Sie können beispielsweise eine E-Mail-Benachrichtigung für Ihr Team konfigurieren, wenn die Antwortzeit für ein bestimmtes URL-Muster einen von Ihnen festgelegten Grenzwert überschreitet.