Ajouter une surveillance personnalisée pour des requêtes réseau spécifiques (applications Apple et Android)


Performance Monitoring collecte des traces pour vous aider à surveiller les performances de votre application. Une trace est un rapport de données de performances capturées entre deux points temporels dans votre application.

Les traces de requêtes réseau collectées automatiquement par Performance Monitoring incluent la plupart des requêtes réseau de votre application. Toutefois, il est possible que certaines requêtes ne soient pas signalées ou que vous utilisiez une autre bibliothèque pour effectuer des requêtes réseau. Dans ce cas, vous pouvez utiliser l'API Performance Monitoring pour instrumenter manuellement les traces de requêtes réseau personnalisées. Les traces de requêtes réseau personnalisées ne sont compatibles qu'avec les applications Apple et Android.

Les métriques par défaut d'une trace de requête réseau personnalisée sont les mêmes que celles des traces de requête réseau collectées automatiquement par Performance Monitoring, à savoir le temps de réponse, la taille de la charge utile de la réponse et de la requête, et le taux de réussite. Les traces de requêtes réseau personnalisées ne permettent pas d'ajouter des métriques personnalisées.

Dans votre code, vous définissez le début et la fin d'une trace de requête réseau personnalisée à l'aide des API fournies par le SDK Performance Monitoring.

Les traces de requêtes réseau personnalisées s'affichent dans la console Firebase, à côté des requêtes réseau que Performance Monitoring capture automatiquement (dans la sous-onglet Requêtes réseau du tableau des traces).

Ajouter des traces de demandes réseau personnalisées

Utilisez l'API HttpMetric Performance Monitoring pour ajouter des traces de requêtes réseau personnalisées afin de surveiller des requêtes réseau spécifiques.

Pour instrumenter manuellement les requêtes réseau personnalisées dans Performance Monitoring, ajoutez un code semblable à ce qui suit :

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

Les traces de requêtes réseau personnalisées permettent également d'ajouter des attributs personnalisés, mais pas des métriques personnalisées.

Étapes suivantes

  • Configurez des alertes pour les requêtes réseau qui dégradent les performances de votre application. Par exemple, vous pouvez configurer une alerte par e-mail pour votre équipe si le temps de réponse pour un modèle d'URL spécifique dépasse un seuil que vous avez défini.