Per consentire agli utenti di attivare o disattivare l'utilizzo di Firebase Performance Monitoring, puoi: vuoi configurare la tua app in modo da poter attivare e disattivare Performance Monitoring. Tu questa funzionalità potrebbe essere utile anche durante lo sviluppo e i test delle app.
Ecco alcune opzioni da prendere in considerazione:
Puoi disattivare l'SDK Performance Monitoring durante la creazione dell'app, con la possibilità di e riattivarla in fase di runtime.
Puoi creare la tua app con l'SDK Performance Monitoring abilitato, ma hai la possibilità di disabilitalo in fase di runtime utilizzando Firebase Remote Config.
Puoi disattivare completamente l'SDK Performance Monitoring, senza alcuna opzione per attivarlo in fase di esecuzione.
Disattiva Performance Monitoring durante il processo di compilazione dell'app
Potrebbe verificarsi una situazione in cui la disattivazione di Performance Monitoring durante il processo di creazione dell'app potrebbe verificarsi è utile evitare di generare report sui dati sul rendimento di una versione pre-release del tuo durante lo sviluppo e i test delle app.
Per disattivare o disattivare Performance Monitoring, puoi aggiungere una delle due chiavi alla
file di elenco delle proprietà (Info.plist
) per la tua app Apple:
Per disattivare Performance Monitoring, ma consentire alla tua app di abilitarlo in fase di runtime, imposta Da
firebase_performance_collection_enabled
afalse
nelInfo.plist
file.Per disattivare completamente Performance Monitoring senza la possibilità di abilitarlo in fase di runtime, imposta
firebase_performance_collection_deactivated
sutrue
nellaInfo.plist
file.
Disattiva la tua app in fase di runtime utilizzando Remote Config
Firebase Remote Config ti consente di modificare il comportamento e l'aspetto della tua app, quindi è il modo ideale per consentirti di disattivare Performance Monitoring di cui è stato eseguito il deployment della tua app.
Per disattivare la raccolta dei dati di Performance Monitoring al prossimo avvio dell'app Apple: utilizza il codice di esempio mostrato di seguito. Per ulteriori informazioni sull'utilizzo di Remote Config in un'app Apple, consulta Utilizzare Firebase Remote Config sulle piattaforme Apple.
Assicurati che Remote Config venga utilizzato in
Podfile
:pod 'Firebase/RemoteConfig'
Aggiungi quanto segue all'inizio del file
AppDelegate
dell'app:Swift
Nota: questo prodotto Firebase non è disponibile sui target macOS, Mac Catalyst e watchOS.import FirebaseRemoteConfig
Objective-C
Nota: questo prodotto Firebase non è disponibile sui target macOS, Mac Catalyst e watchOS.@import FirebaseRemoteConfig;
Nel file
AppDelegate
, aggiungi il seguente codice alaunchOptions
nell'istanzaapplication:didFinishLaunchingWithOptions:
:Swift
Nota: questo prodotto non è disponibile sui target macOS, Mac Catalyst e watchOS.remoteConfig = RemoteConfig.remoteConfig() // You can change the "false" below to "true" to permit more fetches when validating // your app, but you should change it back to "false" or remove this statement before // distributing your app in production. let remoteConfigSettings = RemoteConfigSettings(developerModeEnabled: false) remoteConfig.configSettings = remoteConfigSettings! // Load in-app defaults from a plist file that sets perf_disable to false until // you update values in the Firebase console. remoteConfig.setDefaultsFromPlistFileName("RemoteConfigDefaults") // Important! This needs to be applied before FirebaseApp.configure() if !remoteConfig["perf_disable"].boolValue { // The following line disables all automatic (out-of-the-box) monitoring Performance.sharedInstance().isInstrumentationEnabled = false // The following line disables all custom monitoring Performance.sharedInstance().isDataCollectionEnabled = false } else { Performance.sharedInstance().isInstrumentationEnabled = true Performance.sharedInstance().isDataCollectionEnabled = true } // Use Firebase library to configure APIs FirebaseApp.configure()
Objective-C
Nota: questo prodotto Firebase non è disponibile sui target macOS, Mac Catalyst e watchOS.self.remoteConfig = [FIRRemoteConfig remoteConfig]; // You can change the NO below to YES to permit more fetches when validating // your app, but you should change it back to NO or remove this statement before // distributing your app in production. FIRRemoteConfigSettings *remoteConfigSettings = [[FIRRemoteConfigSettings alloc] initWithDeveloperModeEnabled:NO]; self.remoteConfig.configSettings = remoteConfigSettings; // Load in-app defaults from a plist file that sets perf_disable to false until // you update values in the Firebase console. [self.remoteConfig setDefaultsFromPlistFileName:@"RemoteConfigDefaults"]; // Important! This needs to be applied before [FIRApp configure] if (!self.remoteConfig[@"perf_disable"].numberValue.boolValue) { // The following line disables all automatic (out-of-the-box) monitoring [FIRPerformance sharedInstance].instrumentationEnabled = NO; // The following line disables all custom monitoring [FIRPerformance sharedInstance].dataCollectionEnabled = NO; } else { [FIRPerformance sharedInstance].instrumentationEnabled = YES; [FIRPerformance sharedInstance].dataCollectionEnabled = YES; } // Use Firebase library to configure APIs [FIRApp configure];
In
ViewController.m
o in un altro file di implementazione utilizzato dalla tua app, aggiungi il seguente codice per recuperare e attivare i valori Remote Config:Swift
Nota: questo prodotto Firebase non è disponibile sui target macOS, Mac Catalyst e watchOS.//RemoteConfig fetch and activation in your app, shortly after startup remoteConfig.fetch(withExpirationDuration: TimeInterval(30.0)) { (status, error) -> Void in if status == .success { print("Config fetched!") self.remoteConfig.activateFetched() } else { print("Config not fetched") print("Error \(error!.localizedDescription)") } }
Objective-C
Nota: questo prodotto Firebase non è disponibile sui target macOS, Mac Catalyst e watchOS.//RemoteConfig fetch and activation in your app, shortly after startup [self.remoteConfig fetchWithExpirationDuration:30.0 completionHandler:^(FIRRemoteConfigFetchStatus status, NSError *error) { if (status == FIRRemoteConfigFetchStatusSuccess) { NSLog(@"Config fetched!"); [self.remoteConfig activateFetched]; } else { NSLog(@"Config not fetched"); NSLog(@"Error %@", error.localizedDescription); } }];
Per disabilitare Performance Monitoring nella console Firebase, crea una richiesta perf_disable nel progetto dell'app, quindi imposta il valore su
true
.Se imposti il valore di perf_disable su
false
, Performance Monitoring rimane in un bucket con il controllo delle versioni attivo.
Disattivare la raccolta automatica o personalizzata dei dati separatamente
Puoi apportare alcune modifiche al codice mostrato sopra e nella console Firebase per consentirti di disabilitare il monitoraggio automatico (pronti all'uso) separatamente personalizzato.
Aggiungi il seguente codice alle istruzioni
launchOptions
nella sezione Metodo di istanzaapplication:didFinishLaunchingWithOptions:
(invece di quanto mostrato sopra per lo stesso metodo di istanza):Swift
Nota: questo prodotto Firebase non è disponibile sui target macOS, Mac Catalyst e watchOS.remoteConfig = FIRRemoteConfig.remoteConfig() let remoteConfigSettings = FIRRemoteConfigSettings(developerModeEnabled: true) remoteConfig.configSettings = remoteConfigSettings! // Important! This needs to be applied before FirebaseApp.configure() if remoteConfig["perf_disable_auto"].boolValue { // The following line disables all automatic (out-of-the-box) monitoring Performance.sharedInstance().isInstrumentationEnabled = false } else { Performance.sharedInstance().isInstrumentationEnabled = true } if remoteConfig["perf_disable_manual"].boolValue { // The following line disables all custom monitoring Performance.sharedInstance().isDataCollectionEnabled = false } else { Performance.sharedInstance().isDataCollectionEnabled = true } // Use Firebase library to configure APIs FirebaseApp.configure()
Objective-C
Nota: questo prodotto Firebase non è disponibile sui target macOS, Mac Catalyst e watchOS.self.remoteConfig = [FIRRemoteConfig remoteConfig]; FIRRemoteConfigSettings *remoteConfigSettings = [[FIRRemoteConfigSettings alloc] initWithDeveloperModeEnabled:YES]; self.remoteConfig.configSettings = remoteConfigSettings; // Important! This needs to be applied before [FirebaseApp configure] if (self.remoteConfig[@"perf_disable_auto"].numberValue.boolValue) { // The following line disables all automatic (out-of-the-box) monitoring [FIRPerformance sharedInstance].instrumentationEnabled = NO; } else { [FIRPerformance sharedInstance].instrumentationEnabled = YES; } if (self.remoteConfig[@"perf_disable_manual"].numberValue.boolValue) { // The following line disables all custom monitoring [FIRPerformance sharedInstance].dataCollectionEnabled = NO; } else { [FIRPerformance sharedInstance].dataCollectionEnabled = YES; } // Use Firebase library to configure APIs [FirebaseApp configure];
Nella console Firebase, completa quanto segue:
- Per disabilitare del tutto il monitoraggio automatico (pronti all'uso), crea una
perf_disable_auto nel progetto dell'app, quindi impostane
su
true
. - Per disattivare tutto il monitoraggio personalizzato, crea un parametro perf_disable_manual nel progetto della tua app, quindi imposta il relativo valore su
true
.
- Per disabilitare del tutto il monitoraggio automatico (pronti all'uso), crea una
perf_disable_auto nel progetto dell'app, quindi impostane
su