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

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

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

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

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

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

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

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

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

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

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

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

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

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

  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 पर सेट करें।