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


Bạn có thể sử dụng Cấu hình từ xa Firebase để xác định các thông số trong ứng dụng và cập nhật giá trị của các thông 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ước 1: Thêm Firebase và SDK Cấu hình từ xa vào ứng dụng của bạn

  1. Cài đặt và khởi chạy Firebase SDK cho Flutter nếu bạn chưa làm.

  2. Đối với Cấu hình từ xa, bạn phải sử dụng Google Analytics để nhắm mục tiêu có điều kiện các phiên bản ứng dụng đến thuộc tính người dùng và đối tượng. Đảm bảo bạn bật Google Analytics trong dự án của mình.

  3. Từ thư mục gốc của dự án Flutter, hãy chạy lệnh sau để cài đặt trình bổ trợ Cấu hình từ xa:

    flutter pub add firebase_remote_config
    

    Ngoài ra, trong quá trình thiết lập Cấu hình từ xa, bạn cần thêm Firebase SDK cho Google Analytics vào ứng dụng của mình:

    flutter pub add firebase_analytics
    
  4. Tạo lại dự án:

    flutter run
    
  5. Nếu bạn đang sử dụng Cấu hình từ xa trên macOS, hãy bật Chia sẻ Keychain trong Xcode.

Bước 2: Tải đối tượng singleton Cấu hình từ xa

Tải một phiên bản đối tượng Cấu hình từ xa và đặt khoảng thời gian tìm nạp tối thiểu để cho phép làm mới thường xuyên:

final remoteConfig = FirebaseRemoteConfig.instance;
await remoteConfig.setConfigSettings(RemoteConfigSettings(
    fetchTimeout: const Duration(minutes: 1),
    minimumFetchInterval: const Duration(hours: 1),
));

Đối tượng singleton được 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ợ và kiểm soát thời điểm các giá trị được tìm nạp có sẵn cho ứng dụng của bạn.

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 3: Đặ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 trong đối tượng Cấu hình từ xa, để ứng dụng hoạt động như dự kiến trước khi kết nối với phần phụ trợ Cấu hình từ xa và để các giá trị mặc định có sẵn nếu không có giá trị nào được đặt trong phần phụ trợ.

await remoteConfig.setDefaults(const {
    "example_param_1": 42,
    "example_param_2": 3.14159,
    "example_param_3": true,
    "example_param_4": "Hello, world!",
});

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

Giờ đây, bạn có thể nhận các giá trị tham số từ đối tượng Cấu hình từ xa. Nếu bạn đặt các giá trị ở phần phụ trợ, hãy tìm nạp các giá trị đó rồi kích hoạt chúng, 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 được liệt kê bên dưới, phương thức này sẽ ánh xạ đến kiểu dữ liệu mà ứng dụng của bạn mong đợi, cung cấp khoá tham số làm đối số:

  • getBool()
  • getDouble()
  • getInt()
  • getString()

Bước 5: Đặt giá trị tham số trong phần phụ trợ của Remote Config

Bằng cách sử dụng bảng điều khiển của Firebase hoặc API phần phụ trợ của Cấu hình từ xa, bạn có thể tạo các giá trị mặc định mới phía máy chủ để ghi đè các giá trị trong ứng dụng theo logic có điều kiện hoặc tiêu chí nhắm đến người dùng mà bạn muốn. Phần này mô tả các bước trên bảng điều khiển Firebase để tạo các giá trị này.

  1. Trong bảng điều khiển của Firebase, hãy mở dự án của bạn.
  2. Chọn Cấu hình từ xa trong trình đơn để xem trang tổng quan Cấu hình từ xa.
  3. Xác định các thông số có cùng tên 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 tương ứng 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 bài viết Thông số và điều kiện của Cấu hình từ xa.

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

  1. Để tìm nạp các giá trị tham số từ phần phụ trợ của Remote Config, hãy gọi phương thức fetch(). Mọi giá trị mà bạn đặt trong phần phụ trợ đều được tìm nạp và lưu trữ trong đối tượng Remote Config.

  2. Để cung cấp các giá trị tham số đã tìm nạp cho ứng dụng của bạn, hãy gọi phương thức activate().

    Trong trường hợp muốn tìm nạp và kích hoạt các giá trị trong một lệnh gọi, bạn có thể sử dụng yêu cầu fetchAndActivate() để tìm nạp các giá trị từ phần phụ trợ của Remote Config và cung cấp các giá trị đó cho ứng dụng:

    await remoteConfig.fetchAndActivate();
    

Vì những giá trị tham số đã cập nhật này ảnh hưởng đến hành vi và giao diện của ứng dụng, nên bạn cần kích hoạt các giá trị đã tìm nạp vào thời điểm đảm bảo trải nghiệm mượt mà 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 của bạn. Hãy xem Các chiến lược tải Cấu hình từ xa để biết thêm thông tin và ví dụ.

Bước 7: Lắng 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 để theo dõi các bản cập nhật từ phần phụ trợ của Remote Config. Các tín hiệu Cấu hình từ xa theo thời gian thực cho 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 xuất bản một phiên bản Cấu hình từ xa mới.

Xin lưu ý rằng Remote Config theo thời gian thực không dùng được cho Web.

  1. Trong ứng dụng của bạn, hãy sử dụng onConfigUpdated để bắt đầu theo dõi các bản cập nhật và tự động tìm nạp mọi giá trị tham số mới.

     remoteConfig.onConfigUpdated.listen((event) async {
       await remoteConfig.activate();
    
       // Use the new config values here.
     });
    
  2. Vào lần tiếp theo bạn phát hành một phiên bản mới của Remote Config, những thiết bị đang chạy ứng dụng của bạn và chờ đợi các thay đổi sẽ kích hoạt cấu hình mới.

Đ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à giá trị của thuộc tính lastFetchStatus của FirebaseRemoteConfig sẽ là RemoteConfigFetchStatus.throttle.

Khoảng thời gian tìm nạp tối thiểu mặc định cho Cấu hình từ xa là 12 giờ. Điều này có nghĩa là các cấu hình sẽ không được tìm nạp từ phần phụ trợ nhiều hơn một lần trong khoảng thời gian 12 giờ, bất kể số lượng lệnh gọi tìm nạp thực tế được thực hiện.

Trong quá trình phát triển ứng dụng, nếu không sử dụng Remote Config theo thời gian thực (chúng tôi đề xuất), bạn có thể muốn tìm nạp và kích hoạt cấu hình rất thường xuyên (nhiều lần mỗi giờ) để cho phép bạn lặp lại nhanh chóng khi phát triển và kiểm thử ứng dụng. Để đáp ứng việc lặp lại nhanh chóng trên một dự án có tối đa 10 nhà phát triển, bạn có thể tạm thời đặt khoảng thời gian tìm nạp tối thiểu thấp bằng setConfigSettings().

final remoteConfig = FirebaseRemoteConfig.instance;
await remoteConfig.setConfigSettings(RemoteConfigSettings(
    fetchTimeout: const Duration(minutes: 1),
    minimumFetchInterval: const Duration(minutes: 5),
));

Các bước tiếp theo

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