Durante lo sviluppo e il test dell'app, potrebbe essere utile disattivare Performance Monitoring.
Ad esempio, disattivando durante il processo di compilazione dell'app, puoi:Performance Monitoring
Disattivare alcune funzionalità di Performance Monitoring (ad esempio quelle fornite dal Performance Monitoring plug-in Gradle) nelle build di debug, ma riattivarle per la build di rilascio.
Disattivare Performance Monitoring durante la build dell'app, ma consentire all'app di riattivarlo in fase di runtime.
Disattivare Performance Monitoring durante la build dell'app e non consentire all'app di riattivarlo in fase di runtime.
Puoi anche creare la tua app con Performance Monitoring attivato, ma utilizzare Firebase Remote Config per avere la flessibilità di disattivare (e riattivare) Performance Monitoring nella tua app di produzione. Con questa opzione, puoi persino configurare la tua app in modo che gli utenti possano attivare o disattivare l'utilizzo di Performance Monitoring.
Disattivare Performance Monitoring durante il processo di build dell'app
Puoi disabilitare Performance Monitoring durante il processo di compilazione disabilitando il plug-in Gradle di Performance Monitoring e/o disabilitando la libreria Android di Performance Monitoring.
Durante lo sviluppo e il debug, la disattivazione del plug-in è utile perché l'instrumentazione del plug-in può contribuire ad aumentare il tempo di compilazione. Tuttavia, potresti prendere in considerazione di mantenere attiva la libreria in modo da poter visualizzare i dati sul rendimento dalle tracce di avvio dell'app, dell'app in primo piano e dell'app in background nonché eventuali tracce di codice personalizzato nella tua app.
Disattivare il plug-in Gradle Performance Monitoring
Puoi disattivare il plug-in Performance Monitoring aggiungendo un flag instrumentationEnabled
utilizzando le seguenti opzioni:
Proprietà dell'estensione : disattiva il plug-in per una specifica variante di build in fase di compilazione
Proprietà del progetto : disattiva il plug-in per tutte le varianti di build in fase di compilazione
Disattivare il plug-in tramite un flag della proprietà dell'estensione
Utilizzando un flag della proprietà delle estensioni, puoi disabilitare il plug-in Performance Monitoring per una variante di compilazione specifica in tempo di compilazione.
Nel file Gradle a livello di root (a livello di progetto) (
<project>/build.gradle.ktso<project>/build.gradle), assicurati che la dipendenza del plug-in Android per Gradle sia specificata come v3.4.0 o versioni successive.Per le versioni precedenti del plug-in Android per Gradle, puoi comunque disattivare il plug-in Performance Monitoring per una variante di compilazione specifica, ma il contributo del tempo di compilazione per quella variante non verrà eliminato completamente.
Aggiungi il seguente flag al file Gradle del modulo (a livello di app) (in genere
<project>/<app-module>/build.gradle.ktso<project>/<app-module>/build.gradle), quindi impostalo sufalseper disattivare il plug-in Performance Monitoring.Kotlin
import com.google.firebase.perf.plugin.FirebasePerfExtension // ... android { // ... buildTypes { getByName("debug") { configure<FirebasePerfExtension> { // Set this flag to 'false' to disable @AddTrace annotation processing and // automatic monitoring of HTTP/S network requests // for a specific build variant at compile time. setInstrumentationEnabled(false) } } } }
Groovy
android { // ... buildTypes { debug { FirebasePerformance { // Set this flag to 'false' to disable @AddTrace annotation processing and // automatic monitoring of HTTP/S network requests // for a specific build variant at compile time. instrumentationEnabled false } } } }
Disattivare il plug-in tramite un flag della proprietà del progetto
Utilizzando un flag della proprietà del progetto, puoi disattivare il plug-in Performance Monitoring per tutte le varianti di build in tempo di compilazione.
Aggiungi il seguente flag al file gradle.properties, quindi impostalo su false
per disattivare il plug-in Performance Monitoring.
// ... // Set this flag to 'false' to disable @AddTrace annotation processing and // automatic monitoring of HTTP/S network requests // for all build variants at compile time. firebasePerformanceInstrumentationEnabled=false
Disattivare la libreria Android Performance Monitoring
Se disattivi la libreria Performance Monitoring in tempo di compilazione, puoi scegliere se consentire all'app di attivare la libreria in fase di runtime.
Disattivare la libreria in fase di compilazione, ma consentire all'app di attivarla in fase di runtime
Aggiungi il seguente elemento <meta-data> al AndroidManifest.xml
file dell'app:
<application>
<meta-data
android:name="firebase_performance_collection_enabled"
android:value="false" />
</application>Disattivare la libreria in fase di compilazione, ma non consentire all'app di attivarla in fase di runtime
Aggiungi il seguente elemento <meta-data> al AndroidManifest.xml
file dell'app:
<application>
<meta-data
android:name="firebase_performance_collection_deactivated"
android:value="true" />
</application>Disattivare l'app in fase di runtime utilizzando Remote Config
Firebase Remote Config ti consente di apportare modifiche al comportamento e all'aspetto della tua app, quindi fornisce un modo ideale per disattivare Performance Monitoring nelle istanze di cui è stato eseguito il deployment dell'app.
Per disattivare la raccolta dei dati Performance Monitoring al successivo avvio dell'app per Android, utilizza il codice di esempio riportato di seguito. Per ulteriori informazioni sull'utilizzo di Remote Config in un'app per Android, consulta Utilizzare Firebase Remote Config su Android.
Assicurati che Remote Config sia nella sezione
dependenciesdel file Gradle del modulo (a livello di app) (in genere<project>/<app-module>/build.gradle.ktso<project>/<app-module>/build.gradle):Kotlin
implementation("com.google.firebase:firebase-config-ktx:23.1.0")Java
implementation("com.google.firebase:firebase-config:23.1.0")Configura Remote Config e disattiva Performance Monitoring se
perf_disableè impostato sutrue:Kotlin
// Setup remote config val config = Firebase.remoteConfig // You can uncomment the following two statements to permit more fetches when // validating your app, but you should comment out or delete these lines before // distributing your app in production. // val configSettings = remoteConfigSettings { // minimumFetchIntervalInSeconds = 3600 // } // config.setConfigSettingsAsync(configSettings) // Load in-app defaults from an XML file that sets perf_disable to false until you update // values in the Firebase Console // Observe the remote config parameter "perf_disable" and disable Performance Monitoring if true config.setDefaultsAsync(R.xml.remote_config_defaults) .addOnCompleteListener { task -> if (task.isSuccessful) { Firebase.performance.isPerformanceCollectionEnabled = !config.getBoolean("perf_disable") } else { // An error occurred while setting default parameters } }
Java
// Setup remote config final FirebaseRemoteConfig config = FirebaseRemoteConfig.getInstance(); // You can uncomment the following two statements to permit more fetches when // validating your app, but you should comment out or delete these lines before // distributing your app in production. // FirebaseRemoteConfigSettings configSettings = new FirebaseRemoteConfigSettings.Builder() // .setMinimumFetchIntervalInSeconds(3600) // .build(); // config.setConfigSettingsAsync(configSettings); // Load in-app defaults from an XML file that sets perf_disable to false until you update // values in the Firebase Console //Observe the remote config parameter "perf_disable" and disable Performance Monitoring if true config.setDefaultsAsync(R.xml.remote_config_defaults) .addOnCompleteListener(new OnCompleteListener<Void>() { @Override public void onComplete(@NonNull Task<Void> task) { if (task.isSuccessful()) { if (config.getBoolean("perf_disable")) { FirebasePerformance.getInstance().setPerformanceCollectionEnabled(false); } else { FirebasePerformance.getInstance().setPerformanceCollectionEnabled(true); } } else { // An error occurred while setting default parameters } } });
Aggiungi il seguente codice a
MainActivity.javaper recuperare e attivare Remote Config valori:Kotlin
// Remote Config fetches and activates parameter values from the service val config = Firebase.remoteConfig config.fetch(3600) .continueWithTask { task -> if (!task.isSuccessful) { task.exception?.let { throw it } } config.activate() } .addOnCompleteListener(this) { task -> if (task.isSuccessful) { // Parameter values successfully activated // ... } else { // Handle errors } }
Java
//Remote Config fetches and activates parameter values from the service final FirebaseRemoteConfig config = FirebaseRemoteConfig.getInstance(); config.fetch(3600) .continueWithTask(new Continuation<Void, Task<Boolean>>() { @Override public Task<Boolean> then(@NonNull Task<Void> task) throws Exception { if (!task.isSuccessful()) { throw task.getException(); } return config.activate(); } }) .addOnCompleteListener(new OnCompleteListener<Boolean>() { @Override public void onComplete(@NonNull Task<Boolean> task) { if (task.isSuccessful()) { // Parameter values successfully activated // ... } else { // Handle errors } } });
Per disattivare Performance Monitoring nella console Firebase, crea un parametro perf_disable nel progetto dell'app, quindi imposta il relativo valore su
true.Questa modifica farà sì che le chiamate all'SDK Performance Monitoring siano chiamate "no operation" (NOOP), eliminando eventuali effetti significativi sulle prestazioni dell'app derivanti dall'utilizzo dell'SDK Performance Monitoring nell'app.
Se imposti il valore di perf_disable su
false, Performance Monitoring rimane attivo.