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

Firebase Remote Config cung cấp nhiều tính 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ủ và kích hoạt các giá trị đó trong ứng dụng, cho phép bạn đảm bảo trải nghiệm chất lượng cao cho người dùng cuối bằng cách kiểm soát thời gian của mọi thay đổi 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 về những điều cần cân nhắc chính để 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ể nào về hình ảnh trong giao diện người dùng. Bạn nên tránh đ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ó thể bắt đầu theo dõi các bản cập nhật giá trị thông 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 nội dung cập nhật Remote Config theo thời gian thực bằng cách gọi addOnConfigUpdateListener sẽ hoạt động hiệu quả 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. Thông tin cập nhật theo thời gian thực sẽ 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, hãy không làm gì cả. Ứng dụng của bạn sẽ giữ lại 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 ứng dụng tiếp theo.

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 họ 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 được từ phần thảo luận ở trên về ưu và khuyết điểm của việc tải, bạn nên tránh một số mẫu sử dụng.

  • Đừng cập nhật hoặc chuyển đổi các khía cạnh 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 đó, trừ phi bạn có lý do kinh doanh hoặc ứng dụng chính đáng để làm như vậy, chẳng hạn như xoá các lựa chọn liên quan đến 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. Nên đặ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ỳ thuộc vào nhu cầu của mình, 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.