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 chúng trong ứng dụng của bạn, 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 bất kỳ thay đổi cấu hình hiển thị nào. 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 Cấu hình từ xa theo thời gian thực làm phương pháp bổ sung để tự động tìm nạp các giá trị tham số mới nhất sau khi phiên bản mới của Cấu hình từ xa được xuất bản.
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 cân nhắc chính để chọn tùy 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 của bạn sẽ gọi fetchAndActivate()
khi ứng dụng của bạn khởi động lần đầu tiên để tìm nạp các giá trị mới từ Cấu hình từ xa và kích hoạt chúng ngay sau khi tải xong. Cách tiếp cận đơn giản này hoạt động tốt đối với các thay đổi cấu hình không gây ra bất kỳ thay đổi trực quan đáng kể nào trong giao diện người dùng của bạn. Nó nên tránh trong bất kỳ tình huống nào mà giao diện người dùng của bạn có thể thay đổi đáng kể trong khi người dùng đang sử dụng nó.
Sau khi ứng dụng của bạn gọi fetchAndActivate()
, ứng dụng có thể bắt đầu lắng nghe các cập nhật giá trị tham số trong thời gian thực bằng cách gọi addOnConfigUpdateListener
. Phương pháp này bắt đầu lắng nghe mọi cập nhật phía máy chủ đối với các giá trị tham số, tự động tìm nạp chúng, 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 cho fetchAndActivate()
, nên tránh kích hoạt ngay lập tức đố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 sau màn hình tải trận
Để khắc phục sự cố giao diện người dùng tiềm ẩn 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 của bạn 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 thành của bạn. Sau đó, ngay sau đó - một lần nữa sử dụng lệnh gọi lại hoặc thông báo - loại bỏ 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 của bạn.
Nếu bạn 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 Remote Config có thể là quá lâu đối với trải nghiệm khởi động ứng dụng chất lượng cho người dùng.
Lắng nghe các bản cập nhật Cấu hình từ xa theo thời gian thực bằng cách gọi addOnConfigUpdateListener
hoạt động tốt với chiến lược này. Thêm trình nghe khi màn hình tải được hiển thị, 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ị Cấu hình từ xa sẽ không gây ra những thay đổi lớn về hình ảnh.
Chiến lược 3: Tải các 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 thử 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 được kích hoạt — các giá trị cấu hình mới. Thứ tự các hoạt động cho chiến lược này là:
- Khi khởi động, kích hoạt ngay các giá trị đã tìm nạp trước đó. Điều này áp dụng bất kỳ giá trị nào bạn đã tải xuống từ máy chủ trong phiên trước đó và gần như ngay lập tức.
- Trong khi người dùng tương tác với ứng dụng của bạn, hãy bắt đầu 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 bất kỳ giá trị nào được xuất bản trên máy chủ trong khi ứng dụng của bạn đang chạy. Cập nhật thời gian thực bỏ qua cài đặt khoảng thời gian tìm nạp tối thiểu.
- Trong trình xử lý hoàn thành hoặc gọi lại cho cuộc gọi tìm nạp, không làm gì cả. Ứng dụng của bạn sẽ giữ các giá trị đã tải xuống cho đến khi bạn kích hoạt chúng 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ờ đợi 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 tìm nạp và trình nghe theo thời gian thực với lệnh gọi activate()
khi cần trong vòng đời của ứng dụng để đảm bảo người dùng có các giá trị mới nhất từ Cấu hình từ xa khi họ tương tác với ứng dụng của bạn.
Đang tải các chiến lược chống lại
Như bạn có thể đã hiểu từ cuộc thảo luận ở trên về ưu và nhược điểm tải, có một số cách sử dụng cần tránh.
- Khô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 nó — trừ khi bạn có lý do chính đáng về ứng dụng hoặc doanh nghiệp để làm như vậy, chẳng hạn như xóa các tùy chọn liên quan đến quảng cáo vừa kết thúc.
- Không gửi hàng loạt yêu cầu tìm nạp đồng thời, điều này có thể dẫn đến việc máy chủ điều chỉnh ứng dụng của bạn. Nếu bạn cần thường xuyên tìm nạp các bản cập nhật, hãy sử dụng Cấu hình từ xa thời gian thực . Mặc dù rủi ro điều chỉnh thấp trong hầu hết các tình huống sản xuất, nhưng đây có thể là một vấn đề trong quá trình phát triển tích cực—và Cấu hình từ xa thời gian thực được thiết kế cho trường hợp sử dụng này. Kiểm tra các hướng dẫn tiết lưu .
- Không dựa vào kết nối mạng để nhận các giá trị Cấu hình từ xa. Hãy đặt các giá trị thông 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ộ hóa các giá trị mặc định phụ trợ của ứng dụng và Cấu hình từ xa bằng cách sử dụng các giá trị mặc định của mẫu đã tải xuống .
Bước tiếp theo
Ba chiến lược cơ bản này hoàn toàn không bao gồm một danh sách đầy đủ các cách để tải các giá trị cấu hình. Tùy thuộc vào nhu cầu của bạn, bạn có thể nghĩ ra nhiều chiến lược phức tạp hơn.
Hãy xem tham chiếu API dành 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.