फायरबेस प्रदर्शन निगरानी अक्षम करें

अपने उपयोगकर्ताओं को फायरबेस प्रदर्शन निगरानी का उपयोग करने से ऑप्ट-इन या ऑप्ट-आउट करने देने के लिए, आप अपने ऐप को कॉन्फ़िगर करना चाह सकते हैं ताकि आप प्रदर्शन निगरानी को सक्षम और अक्षम कर सकें। आपको यह क्षमता ऐप डेवलपमेंट और टेस्टिंग के दौरान भी उपयोगी लग सकती है।

विचार करने के लिए निम्नलिखित कुछ विकल्प हैं:

  • आप अपना ऐप बनाते समय प्रदर्शन निगरानी एसडीके को अक्षम कर सकते हैं, इसे रनटाइम पर फिर से सक्षम करने के विकल्प के साथ।

  • आप सक्षम प्रदर्शन निगरानी एसडीके के साथ अपना ऐप बना सकते हैं लेकिन फायरबेस रिमोट कॉन्फिग का उपयोग करके इसे रनटाइम पर अक्षम करने का विकल्प है।

  • आप निष्पादन निगरानी एसडीके को पूरी तरह से निष्क्रिय कर सकते हैं, इसे रनटाइम पर सक्षम करने का कोई विकल्प नहीं है।

अपनी ऐप निर्माण प्रक्रिया के दौरान प्रदर्शन निगरानी अक्षम करें

एक स्थिति जहां आपके ऐप निर्माण प्रक्रिया के दौरान प्रदर्शन निगरानी को अक्षम करना उपयोगी हो सकता है, वह है ऐप डेवलपमेंट और परीक्षण के दौरान अपने ऐप के रिलीज़-पूर्व संस्करण से प्रदर्शन डेटा की रिपोर्ट करने से बचना।

प्रदर्शन निगरानी को अक्षम या निष्क्रिय करने के लिए, आप अपने Apple ऐप के लिए संपत्ति सूची फ़ाइल ( Info.plist ) में दो में से एक कुंजी जोड़ सकते हैं:

  • प्रदर्शन निगरानी को अक्षम करने के लिए, लेकिन अपने ऐप को इसे रनटाइम पर सक्षम करने दें, अपने ऐप की Info.plist फ़ाइल में firebase_performance_collection_enabled को false पर सेट करें।

  • निष्पादन निगरानी को पूरी तरह से निष्क्रिय करने के लिए, इसे रनटाइम पर सक्षम करने के विकल्प के बिना, अपने ऐप की Info.plist फ़ाइल में firebase_performance_collection_deactivated को true पर सेट करें।

रिमोट कॉन्फिग का उपयोग करके अपने ऐप को रनटाइम पर अक्षम करें

फायरबेस रिमोट कॉन्फिग आपको अपने ऐप के व्यवहार और उपस्थिति में बदलाव करने देता है, इसलिए यह आपको अपने ऐप के परिनियोजित इंस्टेंस में प्रदर्शन निगरानी को अक्षम करने का एक आदर्श तरीका प्रदान करता है।

अगली बार जब आपका Apple ऐप शुरू होता है, तो प्रदर्शन निगरानी डेटा संग्रह को अक्षम करने के लिए, नीचे दिखाए गए उदाहरण कोड का उपयोग करें। Apple ऐप में Remote Config का उपयोग करने के बारे में अधिक जानकारी के लिए, Apple प्लेटफॉर्म पर Firebase Remote Config का उपयोग करें देखें।

  1. सुनिश्चित करें कि आपके Podfile में रिमोट कॉन्फ़िगरेशन का उपयोग किया जाता है:

    pod 'Firebase/RemoteConfig'
    
  2. अपने ऐप की AppDelegate फ़ाइल के शीर्ष पर निम्नलिखित जोड़ें:

    तीव्र

    नोट: यह फायरबेस उत्पाद macOS, Mac उत्प्रेरक, watchOS लक्ष्यों पर उपलब्ध नहीं है।
    import FirebaseRemoteConfig
    

    उद्देश्य सी

    नोट: यह फायरबेस उत्पाद macOS, Mac उत्प्रेरक, watchOS लक्ष्यों पर उपलब्ध नहीं है।
    @import FirebaseRemoteConfig;
    
  3. अपनी AppDelegate फ़ाइल में, एप्लिकेशन में launchOptions स्टेटमेंट में निम्न कोड application:didFinishLaunchingWithOptions: इंस्टेंस विधि:

    तीव्र

    नोट: यह उत्पाद macOS, Mac उत्प्रेरक, 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()
    

    उद्देश्य सी

    नोट: यह फायरबेस उत्पाद macOS, Mac उत्प्रेरक, 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];
    
  4. ViewController.m , या आपके ऐप द्वारा उपयोग की जाने वाली अन्य कार्यान्वयन फ़ाइल में, दूरस्थ कॉन्फ़िग मानों को लाने और सक्रिय करने के लिए निम्न कोड जोड़ें:

    तीव्र

    नोट: यह फायरबेस उत्पाद macOS, Mac उत्प्रेरक, 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)")
      }
    }
    

    उद्देश्य सी

    नोट: यह फायरबेस उत्पाद macOS, Mac उत्प्रेरक, 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);
      }
    }];
    
  5. फायरबेस कंसोल में प्रदर्शन निगरानी को अक्षम करने के लिए, अपने ऐप के प्रोजेक्ट में एक perf_disable पैरामीटर बनाएं, फिर उसका मान true पर सेट करें।

    यदि आप perf_disable का मान false पर सेट करते हैं, तो प्रदर्शन निगरानी सक्षम रहती है।

स्वचालित या कस्टम डेटा संग्रह को अलग से अक्षम करें

आप कस्टम मॉनिटरिंग से अलग से सभी स्वचालित (आउट-ऑफ-द-बॉक्स) मॉनिटरिंग को अक्षम करने के लिए ऊपर दिखाए गए कोड और फायरबेस कंसोल में कुछ बदलाव कर सकते हैं।

  1. एप्लिकेशन में launchOptions स्टेटमेंट में निम्न कोड जोड़ें application:didFinishLaunchingWithOptions: इंस्टेंस विधि (उसी इंस्टेंस विधि के लिए ऊपर दिखाए गए के बजाय):

    तीव्र

    नोट: यह फायरबेस उत्पाद macOS, Mac उत्प्रेरक, 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()
    

    उद्देश्य सी

    नोट: यह फायरबेस उत्पाद macOS, Mac उत्प्रेरक, 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];
    
  2. फायरबेस कंसोल में निम्नलिखित को पूरा करें:

    • सभी स्वचालित (आउट-ऑफ़-द-बॉक्स) मॉनिटरिंग को अक्षम करने के लिए, अपने ऐप के प्रोजेक्ट में एक perf_disable_auto पैरामीटर बनाएं, फिर उसका मान true पर सेट करें।
    • सभी कस्टम मॉनिटरिंग को अक्षम करने के लिए, अपने ऐप के प्रोजेक्ट में एक perf_disable_manual पैरामीटर बनाएं, फिर उसका मान true पर सेट करें।