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. 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ó.
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.
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.
- 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ể. Tuy nhiên, người dùng phải chạy ứng dụng của bạn lần thứ hai để xem cấu hình mới nhất. Bạn sẽ cần cân bằng những cân nhắc này với logic ứng dụng và doanh nghiệp của mình.
Đ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. Rủi ro xảy ra điều này là thấp trong hầu hết các kịch bản sản xuất, nhưng nó có thể là một vấn đề trong quá trình phát triển tích cực. Hãy xem hướng dẫn điều tiết dành cho nền tảng Android và Apple .
- 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 mình, bạn có thể nghĩ ra các chiến lược phức tạp hơn nhiều, chẳng hạn như các bản cập nhật nền dựa trên chức năng được mô tả trong Tuyên truyền các bản cập nhật trong thời gian thực .
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.