Добавьте настраиваемый мониторинг для определенных сетевых запросов (приложения Apple и Android).


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 превысит заданное вами пороговое значение.