Chiến lược tải Cấu hình từ xa Firebase

Firebase Remote Config mang lại cho bạn sự linh hoạt về cách thức và thời điểm tìm nạp các giá trị mới từ máy chủ, cũng như kích hoạt các giá trị đó trong ứng dụng của bạn. Việc này cho phép bạn đảm bảo trải nghiệm người dùng cuối chất lượng bằng cách kiểm soát thời gian của mọi thay đổi về cấu hình hiển thị. Bạn có thể tìm nạp các giá trị mới khi khởi chạy ứng dụng bằng cách sử dụng fetchAndActivate() và sử dụng Remote Config theo thời gian thực làm phương thức bổ sung để tự động tìm nạp các giá trị thông số mới nhất sau khi phát hành phiên bản mới của Remote Config.

Hướng dẫn này xem xét một số chiến lược tải và thảo luận các yếu tố chính cần cân nhắc để chọn lựa chọn tốt nhất cho ứng dụng của bạn.

Chiến lược 1: Tìm nạp và kích hoạt khi tải

Trong chiến lược này, ứng dụng sẽ gọi fetchAndActivate() khi khởi động lần đầu để tìm nạp các giá trị mới từ Remote Config và kích hoạt các giá trị đó ngay khi tải xong. Phương pháp đơn giản này hoạt động hiệu quả đối với các thay đổi về cấu hình không gây ra thay đổi đáng kể về hình ảnh trong giao diện người dùng. Bạn nên tránh làm điều này trong mọi trường hợp giao diện người dùng có thể thay đổi đáng kể trong khi người dùng đang sử dụng.

Sau khi gọi fetchAndActivate(), ứng dụng của bạn có thể bắt đầu theo dõi thông tin cập nhật giá trị tham số theo thời gian thực bằng cách gọi addOnConfigUpdateListener. Phương thức này bắt đầu nghe mọi nội dung cập nhật phía máy chủ đối với giá trị tham số, tự động tìm nạp các giá trị đó, sau đó gọi trình nghe. Một chiến lược đơn giản là kích hoạt các giá trị mới trong trình nghe. Tuy nhiên, như đã đề cập đối với fetchAndActivate(), bạn nên tránh kích hoạt ngay đối với các giao diện người dùng nhạy cảm.

Chiến lược 2: Kích hoạt ở chế độ nền sau màn hình tải

Để khắc phục vấn đề tiềm ẩn về giao diện người dùng gặp phải trong chiến lược 1, bạn có thể dựa vào màn hình tải. Thay vì khởi động ứng dụng ngay lập tức, hãy hiển thị màn hình tải và gọi fetchAndActivate trong trình xử lý hoàn tất. Sau đó, ngay lập tức – sử dụng lại lệnh gọi lại hoặc thông báo – hãy đóng màn hình tải và cho phép người dùng bắt đầu tương tác với ứng dụng.

Nếu sử dụng chiến lược này, bạn nên thêm thời gian chờ vào màn hình tải. Thời gian chờ một phút của Cấu hình từ xa có thể quá lâu để mang lại trải nghiệm khởi động ứng dụng chất lượng cho người dùng.

Việc theo dõi thông tin cập nhật theo thời gian thực của Remote Config bằng cách gọi addOnConfigUpdateListener sẽ phù hợp với chiến lược này. Thêm trình nghe khi màn hình tải xuất hiện, sau đó sử dụng activate() tại một hoặc nhiều điểm trong ứng dụng của bạn, nơi các giá trị Remote Config sẽ không gây ra thay đổi đáng kể về hình ảnh.

Chiến lược 3: Tải giá trị mới cho lần khởi động tiếp theo

Một chiến lược hiệu quả là tải các giá trị cấu hình mới để kích hoạt trong lần khởi động tiếp theo của ứng dụng. Trong chiến lược này, ứng dụng của bạn sẽ kích hoạt các giá trị đã tìm nạp khi khởi động trước khi tìm nạp các giá trị mới, hoạt động dựa trên giả định rằng ứng dụng có thể đã tìm nạp nhưng chưa kích hoạt các giá trị cấu hình mới. Thứ tự các thao tác cho chiến lược này là:

  1. Khi khởi động, hãy kích hoạt ngay các giá trị đã tìm nạp trước đó. Thao tác này áp dụng mọi giá trị bạn đã tải xuống từ máy chủ trong một phiên trước đó và gần như tức thì.
  2. Trong khi người dùng tương tác với ứng dụng, hãy bắt đầu một lệnh gọi không đồng bộ để tìm nạp các giá trị mới theo khoảng thời gian tìm nạp tối thiểu mặc định và thêm trình nghe cập nhật cấu hình theo thời gian thực. Trình nghe theo thời gian thực sẽ tự động tìm nạp mọi giá trị được phát hành trên máy chủ trong khi ứng dụng của bạn đang chạy. Các bản cập nhật theo thời gian thực bỏ qua chế độ cài đặt khoảng thời gian tìm nạp tối thiểu.
  3. Trong trình xử lý hoàn tất hoặc lệnh gọi lại cho lệnh gọi tìm nạp, không làm gì cả. Ứng dụng sẽ giữ các giá trị đã tải xuống cho đến khi bạn kích hoạt các giá trị đó vào lần khởi động tiếp theo của ứng dụng.

Với chiến lược này, thời gian chờ của người dùng được giảm thiểu đáng kể. Việc kết hợp các chiến lược trình nghe theo thời gian thực và tìm nạp với các lệnh gọi activate() khi cần trong vòng đời ứng dụng sẽ đảm bảo người dùng có các giá trị mới nhất từ Remote Config khi tương tác với ứng dụng của bạn.

Tải các chiến lược chống lại

Như bạn có thể đã hiểu qua nội dung thảo luận ở trên về ưu và nhược điểm của việc tải, có một số kiểu sử dụng cần tránh.

  • Không cập nhật hoặc chuyển đổi các thành phần của giao diện người dùng trong khi người dùng đang xem hoặc tương tác với giao diện người dùng – trừ phi bạn có lý do chính đáng liên quan đến ứng dụng hoặc hoạt động kinh doanh, chẳng hạn như xoá các lựa chọn liên quan đến một chương trình khuyến mãi vừa kết thúc.
  • Đừng gửi số lượng lớn yêu cầu tìm nạp đồng thời, vì điều này có thể khiến máy chủ điều tiết ứng dụng của bạn. Nếu bạn cần tìm nạp thông tin cập nhật thường xuyên, hãy sử dụng Remote Config theo thời gian thực. Mặc dù rủi ro về việc điều tiết là thấp trong hầu hết các trường hợp sản xuất, nhưng điều này có thể là vấn đề trong quá trình phát triển tích cực. Remote Config theo thời gian thực được thiết kế cho trường hợp sử dụng này. Hãy xem hướng dẫn về việc điều tiết.
  • Đừng dựa vào khả năng kết nối mạng để lấy giá trị Remote Config. Hãy đặt giá trị tham số mặc định trong ứng dụng để ứng dụng của bạn luôn hoạt động như mong đợi. Bạn có thể định kỳ đồng bộ hoá các giá trị mặc định của phần phụ trợ ứng dụng và Remote Config bằng cách sử dụng các giá trị mặc định của mẫu đã tải xuống.

Các bước tiếp theo

Ba chiến lược cơ bản này không bao gồm danh sách đầy đủ các cách tải giá trị cấu hình. Tuỳ theo nhu cầu, bạn có thể nghĩ ra các chiến lược phức tạp hơn nhiều.

Hãy xem tài liệu tham khảo API cho nền tảng của bạn để tìm hiểu thêm về các lệnh gọi cụ thể để tìm nạp và kích hoạt các giá trị cấu hình.