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 Monitoring HttpMetric API, aby dodać niestandardowe logi czasu żądań sieciowych i monitorować konkretne żądania sieciowe.

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

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

Ślady niestandardowych żądań sieciowych obsługują też dodawanie atrybutów niestandardowych, 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.