Performance Monitoring собирает данные о производительности , помогая вам контролировать производительность вашего приложения. Трассировка — это отчёт о данных о производительности, собранных между двумя моментами времени в вашем приложении.
Трассировки сетевых запросов, автоматически собираемые Performance Monitoring охватывают большинство сетевых запросов вашего приложения. Однако некоторые запросы могут не быть включены в отчёты, или вы можете использовать другую библиотеку для выполнения сетевых запросов. В этих случаях вы можете использовать API Performance Monitoring для ручной инструментации пользовательских трассировок сетевых запросов . Пользовательские трассировки сетевых запросов поддерживаются только для приложений Apple и Android.
Метрики по умолчанию для пользовательской трассировки сетевых запросов совпадают с метриками для трассировок сетевых запросов, автоматически собираемыми Performance Monitoring , а именно: время ответа, размер полезной нагрузки ответа и запроса, а также показатель успешности. Пользовательские трассировки сетевых запросов не поддерживают добавление пользовательских метрик.
В своем коде вы определяете начало и конец пользовательской трассировки сетевого запроса, используя API, предоставляемые Performance Monitoring SDK.
Трассировки пользовательских сетевых запросов отображаются в консоли Firebase вместе с сетевыми запросами, которые Performance Monitoring автоматически фиксирует (на подвкладке «Сетевые запросы» таблицы трассировок).
Добавить пользовательские трассировки сетевых запросов
Используйте API HttpMetric Performance Monitoring , чтобы добавлять пользовательские трассировки сетевых запросов для мониторинга определенных сетевых запросов.
Чтобы вручную настроить пользовательские сетевые запросы в Performance Monitoring , добавьте код, аналогичный следующему:
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();
Пользовательские трассировки сетевых запросов также поддерживают добавление пользовательских атрибутов , но не пользовательских метрик.
Следующие шаги
- Настройте оповещения о сетевых запросах, снижающих производительность вашего приложения. Например, вы можете настроить оповещение по электронной почте для своей команды, если время ответа для определённого шаблона URL превысит заданное вами пороговое значение.