Iniziare a utilizzare Performance Monitoring per Android

Prima di iniziare

Se non l'hai già fatto, aggiungi Firebase al tuo progetto Android.

Passaggio 1: aggiungi l'SDK Performance Monitoring alla tua app

Dopo aver aggiunto l'SDK Performance Monitoring, Firebase inizia automaticamente a raccogliere i dati per il rendering dello schermo dell'app e i dati relativi al ciclo di vita dell'app (ad esempio il tempo di avvio dell'app). Per consentire a Firebase di monitorare le richieste di rete, devi anche aggiungere il Performance Monitoring plug-in Gradle (passaggio successivo).

  1. Nel file Gradle del modulo (a livello di app) (in genere <project>/<app-module>/build.gradle.kts o <project>/<app-module>/build.gradle), aggiungi la dipendenza per la libreria Performance Monitoring per Android. Ti consigliamo di utilizzare la Firebase Android BoM per controllare il controllo delle versioni della libreria.

    dependencies {
        // Import the BoM for the Firebase platform
        implementation(platform("com.google.firebase:firebase-bom:34.11.0"))
    
        // Add the dependency for the Performance Monitoring library
        // When using the BoM, you don't specify versions in Firebase library dependencies
        implementation("com.google.firebase:firebase-perf")
    }

    Con la Firebase Android BoM, la tua app utilizzerà sempre versioni compatibili delle librerie Firebase Android.

    (Alternativa)  Aggiungi le dipendenze della libreria Firebase senza utilizzare la BoM

    Se scegli di non utilizzare la Firebase BoM, devi specificare la versione di ogni libreria Firebase nella riga di dipendenza.

    Tieni presente che, se utilizzi più librerie Firebase nella tua app, ti consigliamo vivamente di utilizzare la BoM per gestire le versioni delle librerie, in modo da garantire la compatibilità di tutte le versioni.

    dependencies {
        // Add the dependency for the Performance Monitoring library
        // When NOT using the BoM, you must specify versions in Firebase library dependencies
        implementation("com.google.firebase:firebase-perf:22.0.4")
    }

  2. Ricompila l'app.

Passaggio 2: aggiungi il plug-in Gradle Performance Monitoring alla tua app

Dopo aver aggiunto il plug-in Gradle Performance Monitoring, Firebase inizia automaticamente a raccogliere i dati per le richieste di rete HTTP/S. Il plug-in ti consente anche di instrumentare le tracce di codice personalizzato utilizzando l'annotazione@AddTrace.

  1. Nel file Gradle a livello di root (a livello di progetto) (<project>/build.gradle.kts o <project>/build.gradle), aggiungi il Performance Monitoring plug-in Gradle:

    Kotlin

    plugins {
        // To benefit from the latest Performance Monitoring plugin features,
        // update your Android Gradle plugin dependency to at least v3.4.0
        id("com.android.application") version "7.3.0" apply false
    
        // Make sure that you have the Google services Gradle plugin dependency
        id("com.google.gms.google-services") version "4.4.4" apply false
    
        // Add the dependency for the Performance Monitoring Gradle plugin
        id("com.google.firebase.firebase-perf") version "2.0.2" apply false
    }

    Groovy

    plugins {
        // To benefit from the latest Performance Monitoring plugin features,
        // update your Android Gradle plugin dependency to at least v3.4.0
        id 'com.android.application' version '7.3.0' apply false
    
        // Make sure that you have the Google services Gradle plugin dependency
        id 'com.google.gms.google-services' version '4.4.4' apply false
    
        // Add the dependency for the Performance Monitoring Gradle plugin
        id 'com.google.firebase.firebase-perf' version '2.0.2' apply false
    }
  2. Nel file Gradle del modulo (a livello di app) (in genere <project>/<app-module>/build.gradle.kts o <project>/<app-module>/build.gradle), aggiungi il plug-in Gradle Performance Monitoring:

    Kotlin

    plugins {
        id("com.android.application")
    
        // Make sure that you have the Google services Gradle plugin
        id("com.google.gms.google-services")
    
        // Add the Performance Monitoring Gradle plugin
        id("com.google.firebase.firebase-perf")
        ...
    }

    Groovy

    plugins {
        id 'com.android.application'
    
        // Make sure that you have the Google services Gradle plugin
        id 'com.google.gms.google-services'
    
        // Add the Performance Monitoring Gradle plugin
        id 'com.google.firebase.firebase-perf'
        ...
    }
  3. Ricompila l'app.

Passaggio 3: genera eventi di rendimento per la visualizzazione iniziale dei dati

Firebase inizia a elaborare gli eventi quando aggiungi correttamente l'SDK alla tua app. Se stai ancora sviluppando in locale, interagisci con l'app per generare eventi per la raccolta dei dati e l'elaborazione iniziale.

  1. Genera eventi passando l'app in background e in primo piano più volte, interagendo con l'app spostandoti tra le schermate e/o attivando le richieste di rete.

  2. Vai alla dashboard Rendimento della console Firebase. Dovresti visualizzare i dati iniziali entro pochi minuti.

    Se non vedi la visualizzazione dei dati iniziali, consulta i suggerimenti per la risoluzione dei problemi.

Passaggio 4: (facoltativo) visualizza i messaggi di log per gli eventi di rendimento

  1. Attiva la registrazione di debug per Performance Monitoring in fase di compilazione aggiungendo un <meta-data> elemento al file AndroidManifest.xml dell'app, come segue:

    <application>
        <meta-data
          android:name="firebase_performance_logcat_enabled"
          android:value="true" />
    </application>
  2. Controlla i messaggi di log per eventuali messaggi di errore.

  3. Performance Monitoring contrassegna i messaggi di log con FirebasePerformance. Utilizzando il filtro logcat, puoi visualizzare in modo specifico la registrazione della durata di visualizzazione e della richiesta di rete HTTP/S eseguendo il seguente comando:

    adb logcat -s FirebasePerformance
  4. Controlla i seguenti tipi di log che indicano che Performance Monitoring sta registrando gli eventi di rendimento:

    • Logging trace metric: TRACE_NAME, FIREBASE_PERFORMANCE_CONSOLE_URL
    • Logging network request trace: URL
  5. Fai clic sull'URL per visualizzare i dati nella Console Firebase. L'aggiornamento dei dati nella dashboard potrebbe richiedere alcuni istanti.

Se la tua app non registra gli eventi di rendimento, consulta i suggerimenti per la risoluzione dei problemi.

Passaggio 5: (facoltativo) aggiungi il monitoraggio personalizzato per codice specifico

Per monitorare i dati sul rendimento associati a un codice specifico nella tua app, puoi instrumentare le tracce di codice personalizzato.

Con una traccia di codice personalizzato, puoi misurare il tempo impiegato dalla tua app per completare un'attività o un insieme di attività specifiche, ad esempio il caricamento di un insieme di immagini o l'esecuzione di query sul database. La metrica predefinita per una traccia di codice personalizzato è la sua durata, ma puoi anche aggiungere metriche personalizzate, come hit della cache e avvisi di memoria.

Nel codice, definisci l'inizio e la fine di una traccia di codice personalizzato (e aggiungi le metriche personalizzate che preferisci) utilizzando l'API fornita dall'Performance Monitoring SDK. Per le app Android, puoi anche monitorare la durata di metodi specifici utilizzando l'annotazione@AddTrace.

Visita la pagina Aggiungere il monitoraggio per codice specifico per scoprire di più su queste funzionalità e su come aggiungerle alla tua app.

Passaggio 6: esegui il deployment dell'app e poi esamina i risultati

Dopo aver convalidato Performance Monitoring utilizzando uno o più dispositivi di test, puoi eseguire il deployment della versione aggiornata dell'app per i tuoi utenti.

Puoi monitorare i dati sul rendimento nella dashboard della Firebase console.

Problemi noti

  • Il plug-in Gradle Performance Monitoring v1.1.0 può causare una mancata corrispondenza nelle dipendenze Guava, con il conseguente errore:

    Error:Execution failed for task ':app:packageInstantRunResourcesDebug'.
    > com.google.common.util.concurrent.MoreExecutors.directExecutor()Ljava/util/concurrent/Executor;

    Se visualizzi questo errore, puoi:

    • Eseguire l'upgrade del plug-in Performance Monitoring alla versione 1.1.1 o successive (la più recente è v2.0.2).

    • Sostituire la riga di dipendenza del plug-in Performance Monitoring nel file Gradle a livello di root (a livello di progetto) (<project>/build.gradle.kts o <project>/build.gradle), come segue:

      Kotlin

      buildscript {
        // ...
      
        dependencies {
          // ...
      
          // Replace the standard Performance Monitoring plugin dependency line, as follows:
          classpath("com.google.firebase:perf-plugin:1.1.0") {
              exclude(group = "com.google.guava", module = "guava-jdk5")
          }
        }
      }

      Groovy

      buildscript {
        // ...
      
        dependencies {
          // ...
      
          // Replace the standard Performance Monitoring plugin dependency line, as follows:
          classpath('com.google.firebase:perf-plugin:1.1.0') {
              exclude group: 'com.google.guava', module: 'guava-jdk5'
          }
        }
      }
  • Performance Monitoring segnala le dimensioni totali del payload per le richieste di rete HTTP in base al valore impostato nell'intestazione HTTP content-length. Questo valore potrebbe non essere sempre accurato.

  • Performance Monitoring supporta solo il processo principale nelle app Android multiprocesso.

Passaggi successivi