Kullanıcılarınızın Firebase Performance Monitoring'ü etkinleştirmesine veya devre dışı bırakmasına izin vermek için uygulamanızı Firebase Performance Monitoring'ü etkinleştirip devre dışı bırakabileceğiniz şekilde yapılandırabilirsiniz.Performance Monitoring Bu özelliği uygulama geliştirme ve test sırasında da faydalı bulabilirsiniz.
Aşağıda, dikkate alabileceğiniz bazı seçenekler verilmiştir:
Uygulamanızı oluştururken Performance Monitoring SDK'sını devre dışı bırakabilir ve çalışma zamanında yeniden etkinleştirme seçeneğini belirleyebilirsiniz.
Uygulamanızı Performance Monitoring SDK'sı etkinken derleyebilirsiniz ancak Firebase Remote Config kullanarak çalışma zamanında devre dışı bırakma seçeneğiniz vardır.
Performance Monitoring SDK'sını çalışma zamanında etkinleştirme seçeneği olmadan tamamen devre dışı bırakabilirsiniz.
Uygulama oluşturma işleminiz sırasında Performance Monitoring'ü devre dışı bırakma
Uygulama oluşturma işleminiz sırasında Performance Monitoring'ü devre dışı bırakmanın yararlı olabileceği bir durum, uygulama geliştirme ve test sırasında uygulamanızın yayın öncesi sürümüne ait performans verilerinin raporlanmasını önlemektir.
Performance Monitoring'ü devre dışı bırakmak için Apple uygulamanızın mülk listesi dosyasına (Info.plist
) iki anahtardan birini ekleyebilirsiniz:
Performance Monitoring'ü devre dışı bırakmak ancak uygulamanızın çalışma zamanında etkinleştirmesine izin vermek için uygulamanızın
Info.plist
dosyasındafirebase_performance_collection_enabled
değerinifalse
olarak ayarlayın.Performance Monitoring'ü çalışma zamanında etkinleştirme seçeneği olmadan tamamen devre dışı bırakmak için uygulamanızın
Info.plist
dosyasındafirebase_performance_collection_deactivated
değerinitrue
olarak ayarlayın.
Remote Config kullanarak uygulamanızı çalışma zamanında devre dışı bırakma
Firebase Remote Config, uygulamanızın davranışında ve görünümünde değişiklik yapmanıza olanak tanır. Bu nedenle, uygulamanızın dağıtılan örneklerindeki Performance Monitoring'ı devre dışı bırakmak için ideal bir yöntemdir.
Apple uygulamanız bir sonraki sefer başlatıldığında Performance Monitoring veri toplamayı devre dışı bırakmak için aşağıda gösterilen örnek kodu kullanın. Remote Config'ü Apple uygulamalarında kullanma hakkında daha fazla bilgi için Apple platformlarında Firebase Remote Config kullanma başlıklı makaleyi inceleyin.
Podfile
cihazınızda Remote Config'nin kullanıldığından emin olun:pod 'Firebase/RemoteConfig'
Uygulamanızın
AppDelegate
dosyasının en üstüne aşağıdakileri ekleyin:Swift
Not: Bu Firebase ürünü macOS, Mac Catalyst ve watchOS hedeflerinde kullanılamaz.import FirebaseRemoteConfig
Objective-C
Not: Bu Firebase ürünü macOS, Mac Catalyst ve watchOS hedeflerinde kullanılamaz.@import FirebaseRemoteConfig;
AppDelegate
dosyanızda,application:didFinishLaunchingWithOptions:
örnek yöntemindekilaunchOptions
ifadelerine aşağıdaki kodu ekleyin:Swift
Not: Bu ürün macOS, Mac Catalyst ve watchOS hedeflerinde kullanılamaz.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
Not: Bu Firebase ürünü macOS, Mac Catalyst ve watchOS hedeflerinde kullanılamaz.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];
ViewController.m
dosyasına veya uygulamanız tarafından kullanılan başka bir uygulama dosyasına Remote Config değerlerini almak ve etkinleştirmek için aşağıdaki kodu ekleyin:Swift
Not: Bu Firebase ürünü macOS, Mac Catalyst ve watchOS hedeflerinde kullanılamaz.//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
Not: Bu Firebase ürünü macOS, Mac Catalyst ve watchOS hedeflerinde kullanılamaz.//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); } }];
Firebase konsolunda Performance Monitoring'ü devre dışı bırakmak için uygulamanızın projesinde bir perf_disable parametresi oluşturun ve ardından parametrenin değerini
true
olarak ayarlayın.perf_disable değerini
false
olarak ayarlarsanız Performance Monitoring etkin kalır.
Otomatik veya özel veri toplamayı ayrı ayrı devre dışı bırakma
Yukarıda gösterilen kodda ve Firebase konsolunda bazı değişiklikler yaparak tüm otomatik (kullanıma hazır) izlemeyi özel izlemeden ayrı olarak devre dışı bırakabilirsiniz.
Aşağıdaki kodu,
application:didFinishLaunchingWithOptions:
örnek yöntemindekilaunchOptions
ifadelerine ekleyin (aynı örnek yöntem için yukarıda gösterilen yerine):Swift
Not: Bu Firebase ürünü macOS, Mac Catalyst ve watchOS hedeflerinde kullanılamaz.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
Not: Bu Firebase ürünü macOS, Mac Catalyst ve watchOS hedeflerinde kullanılamaz.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];
Firebase konsolunda aşağıdakileri tamamlayın:
- Tüm otomatik (kullanıma hazır) izlemeyi devre dışı bırakmak için uygulamanızın projesinde bir perf_disable_auto parametresi oluşturun ve ardından değerini
true
olarak ayarlayın. - Tüm özel izlemeyi devre dışı bırakmak için uygulamanızın projesinde bir perf_disable_manual parametresi oluşturun ve ardından parametrenin değerini
true
olarak ayarlayın.
- Tüm otomatik (kullanıma hazır) izlemeyi devre dışı bırakmak için uygulamanızın projesinde bir perf_disable_auto parametresi oluşturun ve ardından değerini