Menambahkan pemantauan kustom untuk permintaan jaringan tertentu (aplikasi Apple & Android)

Performance Monitoring mengumpulkan trace untuk membantu Anda memantau performa aplikasi. Trace adalah laporan data performa yang dicatat antara dua titik waktu dalam aplikasi Anda.

Trace permintaan jaringan yang otomatis dikumpulkan oleh Performance Monitoring mencakup sebagian besar permintaan jaringan untuk aplikasi Anda. Namun, beberapa permintaan mungkin tidak dilaporkan atau Anda kemungkinan menggunakan library yang berbeda untuk membuat permintaan jaringan. Dalam hal ini, Anda dapat menggunakan Performance Monitoring API untuk menginstrumentasikan trace permintaan jaringan kustom secara manual. Trace permintaan jaringan kustom hanya didukung untuk aplikasi Apple dan Android.

Metrik default untuk trace permintaan jaringan kustom sama dengan metrik untuk trace permintaan jaringan yang otomatis dikumpulkan oleh Performance Monitoring, terutama waktu respons, ukuran payload respons dan payload permintaan, serta tingkat keberhasilan. Trace permintaan jaringan kustom tidak mendukung penambahan metrik kustom.

Dalam kode, penentuan awal dan akhir trace permintaan jaringan kustom dilakukan menggunakan API yang diberikan oleh Performance Monitoring SDK.

Trace permintaan jaringan kustom muncul di Firebase console bersama permintaan jaringan yang dicatat Performance Monitoring secara otomatis (di subtab Network requests pada tabel trace).

Menambahkan trace permintaan jaringan kustom

Gunakan Performance Monitoring HttpMetric API untuk menambahkan trace permintaan jaringan kustom untuk memantau permintaan jaringan tertentu.

Untuk menginstrumentasikan permintaan jaringan kustom secara manual di Performance Monitoring, tambahkan kode yang mirip dengan berikut:

Kotlin+KTX

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

Trace permintaan jaringan kustom juga mendukung penambahan atribut khusus, tetapi tidak mendukung metrik kustom.

Langkah berikutnya

  • Siapkan pemberitahuan untuk permintaan jaringan yang menurunkan performa aplikasi Anda. Misalnya, Anda dapat mengonfigurasi peringatan email untuk tim jika waktu respons untuk pola URL tertentu melebihi batas yang Anda tetapkan.