Bắt đầu sử dụng Cấu hình từ xa Firebase


Bạn có thể sử dụng Firebase Remote Config để xác định các tham số trong ứng dụng và cập nhật giá trị của các tham số đó trên đám mây, cho phép bạn sửa đổi giao diện và hành vi của ứng dụng mà không cần phân phối bản cập nhật ứng dụng. Hướng dẫn này sẽ hướng dẫn bạn các bước để bắt đầu và cung cấp một số mã mẫu. Bạn có thể sao chép hoặc tải tất cả mã này xuống từ kho lưu trữ GitHub firebase/quickstart-ios.

Bước 1: Thêm Remote Config vào ứng dụng

  1. Thêm Firebase vào dự án Apple của bạn nếu bạn chưa thêm.

  2. Đối với Remote Config, bạn phải có Google Analytics để nhắm mục tiêu có điều kiện các thực thể ứng dụng đến thuộc tính người dùng và đối tượng. Hãy nhớ bật Google Analytics trong dự án của bạn.

  3. Tạo đối tượng singleton Remote Config, như trong ví dụ sau:

    Swift

    remoteConfig = RemoteConfig.remoteConfig()
    let settings = RemoteConfigSettings()
    settings.minimumFetchInterval = 0
    remoteConfig.configSettings = settings

    Objective-C

    self.remoteConfig = [FIRRemoteConfig remoteConfig];
    FIRRemoteConfigSettings *remoteConfigSettings = [[FIRRemoteConfigSettings alloc] init];
    remoteConfigSettings.minimumFetchInterval = 0;
    self.remoteConfig.configSettings = remoteConfigSettings;

Đối tượng này dùng để lưu trữ các giá trị tham số mặc định trong ứng dụng, tìm nạp các giá trị tham số đã cập nhật từ phần phụ trợ Remote Config và kiểm soát thời điểm cung cấp các giá trị đã tìm nạp cho ứng dụng.

Trong quá trình phát triển, bạn nên đặt khoảng thời gian tìm nạp tối thiểu tương đối thấp. Hãy xem phần Điều tiết để biết thêm thông tin.

Bước 2: Đặt giá trị tham số mặc định trong ứng dụng

Bạn có thể đặt các giá trị tham số mặc định trong ứng dụng ở đối tượng Remote Config để ứng dụng hoạt động như dự kiến trước khi kết nối với phần phụ trợ Remote Config, và để các giá trị mặc định sẽ có sẵn nếu không có giá trị nào được đặt trong phần phụ trợ.

  1. Xác định một tập hợp tên thông số và giá trị thông số mặc định bằng cách sử dụng đối tượng NSDictionary hoặc tệp plist.

    Nếu đã định cấu hình giá trị tham số phụ trợ Remote Config, bạn có thể tải tệp plist đã tạo có chứa tất cả giá trị mặc định xuống rồi lưu vào dự án Xcode của mình.

    Kiến trúc chuyển trạng thái đại diện (REST)

    curl --compressed -D headers -H "Authorization: Bearer token -X GET https://firebaseremoteconfig.googleapis.com/v1/projects/my-project-id/remoteConfig:downloadDefaults?format=PLIST -o RemoteConfigDefaults.plist
    

    Bảng điều khiển Firebase

    1. Trong thẻ Parameters (Thông số), hãy mở Menu (Trình đơn) rồi chọn Download default values (Tải giá trị mặc định xuống).

    2. Khi được nhắc, hãy bật .plist cho iOS, sau đó nhấp vào Tải tệp xuống.

  2. Thêm các giá trị này vào đối tượng Remote Config bằng cách sử dụng setDefaults:. Ví dụ sau đây thiết lập các giá trị mặc định trong ứng dụng từ tệp plist:

    Swift

    remoteConfig.setDefaults(fromPlist: "RemoteConfigDefaults")

    Objective-C

    [self.remoteConfig setDefaultsFromPlistFileName:@"RemoteConfigDefaults"];

Bước 3: Nhận giá trị thông số để sử dụng trong ứng dụng

Bây giờ, bạn có thể lấy giá trị tham số từ đối tượng Remote Config. Nếu sau đó bạn đặt giá trị trong phần phụ trợ Remote Config, tìm nạp rồi kích hoạt các giá trị đó, thì ứng dụng của bạn sẽ có các giá trị đó. Nếu không, bạn sẽ nhận được các giá trị tham số trong ứng dụng được định cấu hình bằng setDefaults:. Để lấy các giá trị này, hãy gọi phương thức configValueForKey:, cung cấp khoá tham số làm đối số.

Bước 4: Đặt giá trị tham số

Khi sử dụng bảng điều khiển Firebase hoặc API phần phụ trợ Remote Config, bạn có thể tạo các giá trị mặc định mới cho phần phụ trợ để ghi đè các giá trị trong ứng dụng theo logic có điều kiện hoặc tiêu chí nhắm mục tiêu người dùng mà bạn muốn. Phần này hướng dẫn bạn các bước trong bảng điều khiển Firebase để tạo các giá trị này.

  1. Trong bảng điều khiển Firebase, hãy mở dự án của bạn.
  2. Chọn Remote Config trong trình đơn để xem trang tổng quan Remote Config.
  3. Xác định các thông số có tên giống với các thông số mà bạn đã xác định trong ứng dụng. Đối với mỗi thông số, bạn có thể đặt một giá trị mặc định (cuối cùng sẽ ghi đè giá trị mặc định trong ứng dụng) và bạn cũng có thể đặt các giá trị có điều kiện. Để tìm hiểu thêm, hãy xem phần Thông số và điều kiện của Remote Config.

Bước 5: Tìm nạp và kích hoạt các giá trị

Để tìm nạp giá trị tham số từ Remote Config, hãy gọi phương thức fetchWithCompletionHandler: hoặc fetchWithExpirationDuration:completionHandler:. Mọi giá trị mà bạn đặt trên phần phụ trợ đều được tìm nạp và lưu vào bộ nhớ đệm trong đối tượng Remote Config.

Trong trường hợp bạn muốn tìm nạp và kích hoạt các giá trị trong một lệnh gọi, hãy sử dụng fetchAndActivateWithCompletionHandler:.

Ví dụ này tìm nạp các giá trị từ phần phụ trợ Remote Config (không phải giá trị được lưu vào bộ nhớ đệm) và lệnh gọiactivateWithCompletionHandler: để cung cấp các giá trị đó cho ứng dụng:

Swift

remoteConfig.fetch { (status, error) -> Void in
  if status == .success {
    print("Config fetched!")
    self.remoteConfig.activate { changed, error in
      // ...
    }
  } else {
    print("Config not fetched")
    print("Error: \(error?.localizedDescription ?? "No error available.")")
  }
  self.displayWelcome()
}

Objective-C

[self.remoteConfig fetchWithCompletionHandler:^(FIRRemoteConfigFetchStatus status, NSError *error) {
    if (status == FIRRemoteConfigFetchStatusSuccess) {
        NSLog(@"Config fetched!");
      [self.remoteConfig activateWithCompletion:^(BOOL changed, NSError * _Nullable error) {
        if (error != nil) {
          NSLog(@"Activate error: %@", error.localizedDescription);
        } else {
          dispatch_async(dispatch_get_main_queue(), ^{
            [self displayWelcome];
          });
        }
      }];
    } else {
        NSLog(@"Config not fetched");
        NSLog(@"Error %@", error.localizedDescription);
    }
}];

Vì các giá trị thông số đã cập nhật này ảnh hưởng đến hành vi và giao diện của ứng dụng, bạn nên kích hoạt các giá trị đã tìm nạp cùng lúc để đảm bảo trải nghiệm suôn sẻ cho người dùng, chẳng hạn như vào lần tiếp theo người dùng mở ứng dụng. Hãy xem chiến lược tải Cấu hình từ xa để biết thêm thông tin và ví dụ.

Bước 6: Nghe thông tin cập nhật theo thời gian thực

Sau khi tìm nạp các giá trị tham số, bạn có thể sử dụng Remote Config theo thời gian thực để nghe thông tin cập nhật từ phần phụ trợ Remote Config. Remote Config theo thời gian thực phát tín hiệu đến các thiết bị được kết nối khi có bản cập nhật và tự động tìm nạp các thay đổi sau khi bạn phát hành phiên bản Remote Config mới.

SDK Firebase hỗ trợ tính năng cập nhật theo thời gian thực cho các nền tảng Apple phiên bản 10.7.0 trở lên.

  1. Trong ứng dụng, hãy gọi addOnConfigUpdateListener để bắt đầu nghe thông tin cập nhật và tự động tìm nạp mọi giá trị thông số mới hoặc đã cập nhật. Ví dụ sau đây sẽ theo dõi các bản cập nhật và khi activateWithCompletionHandler được gọi, hệ thống sẽ dùng các giá trị mới tìm nạp được để cho thấy thông báo chào mừng đã cập nhật.

    Swift

    remoteConfig.addOnConfigUpdateListener { configUpdate, error in
      guard let configUpdate, error == nil else {
        print("Error listening for config updates: \(error)")
      }
    
      print("Updated keys: \(configUpdate.updatedKeys)")
    
      self.remoteConfig.activate { changed, error in
        guard error == nil else { return self.displayError(error) }
        DispatchQueue.main.async {
          self.displayWelcome()
        }
      }
    }

    Objective-C

    __weak __typeof__(self) weakSelf = self;
    [self.remoteConfig addOnConfigUpdateListener:^(FIRRemoteConfigUpdate * _Nonnull configUpdate, NSError * _Nullable error) {
      if (error != nil) {
        NSLog(@"Error listening for config updates %@", error.localizedDescription);
      } else {
        NSLog(@"Updated keys: %@", configUpdate.updatedKeys);
    
        __typeof__(self) strongSelf = weakSelf;
        [strongSelf.remoteConfig activateWithCompletion:^(BOOL changed, NSError * _Nullable error) {
          if (error != nil) {
            NSLog(@"Activate error %@", error.localizedDescription);
          }
    
          dispatch_async(dispatch_get_main_queue(), ^{
            [strongSelf displayWelcome];
          });
        }];
      }
    }];
  2. Vào lần tiếp theo bạn phát hành phiên bản mới của Remote Config, các thiết bị đang chạy ứng dụng của bạn và theo dõi các thay đổi sẽ gọi trình xử lý hoàn thành.

Điều tiết

Nếu một ứng dụng tìm nạp quá nhiều lần trong một khoảng thời gian ngắn, thì các lệnh gọi tìm nạp sẽ bị điều tiết và SDK sẽ trả về FIRRemoteConfigFetchStatusThrottled. Trước SDK phiên bản 6.3.0, giới hạn là 5 yêu cầu tìm nạp trong khoảng thời gian 60 phút (các phiên bản mới hơn có giới hạn nới lỏng hơn).

Trong quá trình phát triển ứng dụng,bạn nên tìm nạp thường xuyên hơn để làm mới bộ nhớ đệm rất thường xuyên (nhiều lần mỗi giờ) để có thể lặp lại nhanh chóng khi phát triển và kiểm thử ứng dụng. Các bản cập nhật Cấu hình từ xa theo thời gian thực sẽ tự động bỏ qua bộ nhớ đệm khi cấu hình được cập nhật trên máy chủ. Để thích ứng với việc lặp lại nhanh trên một dự án có nhiều nhà phát triển, bạn có thể tạm thời thêm một thuộc tính FIRRemoteConfigSettings có khoảng thời gian tìm nạp tối thiểu thấp (MinimumFetchInterval) trong ứng dụng.

Khoảng thời gian tìm nạp mặc định và được đề xuất cho Remote Config là 12 giờ, tức là hệ thống sẽ không tìm nạp các cấu hình qua phần phụ trợ nhiều lần trong khoảng thời gian 12 giờ, bất kể thực tế có bao nhiêu lệnh gọi tìm nạp. Cụ thể, khoảng thời gian tìm nạp tối thiểu được xác định theo thứ tự sau:

  1. Tham số trong fetch(long)
  2. Tham số trong FIRRemoteConfigSettings.MinimumFetchInterval
  3. Giá trị mặc định của 12 giờ

Các bước tiếp theo

Nếu bạn chưa từng khám phá, hãy tìm hiểu các trường hợp sử dụng của Remote Config và xem một số khái niệm chính cũng như tài liệu về chiến lược nâng cao, bao gồm: