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.