Tránh tải xuống khi chưa được tối ưu hoá

Một số người dùng ứng dụng của bạn truy cập gián đoạn vào Internet hoặc bị giới hạn về lượng thông tin họ có thể tải xuống thiết bị của mình. Bạn có thể khuyến khích người dùng tương tác với ứng dụng của mình thường xuyên hơn bằng cách giảm lượng dữ liệu mà ứng dụng của bạn cần tải xuống.

Cách cơ bản nhất để giảm số lượt tải xuống là chỉ tải những dữ liệu bạn cần xuống. Về dữ liệu, điều đó có nghĩa là bạn phải triển khai các API REST cho phép chỉ định tiêu chí truy vấn giới hạn dữ liệu được trả về bằng các tham số, chẳng hạn như thời gian cập nhật gần đây nhất.

Tương tự, khi tải hình ảnh xuống, bạn nên giảm kích thước của hình ảnh phía máy chủ, thay vì tải hình ảnh có kích thước đầy đủ bị giảm trên máy khách.

Lưu phản hồi HTTP vào bộ nhớ đệm

Một kỹ thuật quan trọng khác là tránh tải dữ liệu trùng lặp xuống. Bạn có thể giảm khả năng tải cùng một phần dữ liệu xuống nhiều lần bằng cách sử dụng tính năng lưu vào bộ nhớ đệm. Bằng cách lưu dữ liệu và tài nguyên của ứng dụng vào bộ nhớ đệm, bạn sẽ tạo một bản sao cục bộ của thông tin mà ứng dụng cần tham chiếu. Nếu ứng dụng của bạn cần truy cập vào cùng một phần thông tin nhiều lần trong một khoảng thời gian ngắn, thì bạn chỉ cần tải thông tin đó xuống bộ nhớ đệm một lần.

Bạn cần lưu vào bộ nhớ đệm thường xuyên nhất có thể để giảm tổng lượng dữ liệu tải xuống. Luôn lưu các tài nguyên tĩnh vào bộ nhớ đệm, bao gồm cả các tài nguyên tải xuống theo yêu cầu, chẳng hạn như hình ảnh có kích thước đầy đủ, trong thời gian hợp lý có thể. Các tài nguyên theo yêu cầu phải được lưu trữ riêng biệt để bạn có thể thường xuyên xoá bộ nhớ đệm theo yêu cầu nhằm quản lý dung lượng của nó.

Để đảm bảo việc lưu vào bộ nhớ đệm không làm ứng dụng của bạn hiển thị dữ liệu lỗi thời, hãy dùng các mã và tiêu đề trạng thái HTTP thích hợp, chẳng hạn như các tiêu đề ETagLast-Modified. Điều này cho phép bạn xác định thời điểm cần làm mới nội dung liên quan. Ví dụ:

Kotlin

// url represents the website containing the content to place into the cache.
val conn: HttpsURLConnection = url.openConnection() as HttpsURLConnection
val currentTime: Long = System.currentTimeMillis()
val lastModified: Long = conn.getHeaderFieldDate("Last-Modified", currentTime)

// lastUpdateTime represents when the cache was last updated.
if (lastModified < lastUpdateTime) {
    // Skip update
} else {
    // Parse update
    lastUpdateTime = lastModified
}

Java

// url represents the website containing the content to place into the cache.
HttpsURLConnection conn = (HttpsURLConnection) url.openConnection();
long currentTime = System.currentTimeMillis();
long lastModified = conn.getHeaderFieldDate("Last-Modified", currentTime);

// lastUpdateTime represents when the cache was last updated.
if (lastModified < lastUpdateTime) {
    // Skip update
} else {
    // Parse update
    lastUpdateTime = lastModified;
}

Bạn có thể định cấu hình một số thư viện nối mạng để tự động tuân theo các mã trạng thái và tiêu đề này. Ví dụ: khi sử dụng OkHttp, việc định cấu hình thư mục bộ nhớ đệm và dung lượng bộ nhớ đệm cho ứng dụng sẽ cho phép thư viện sử dụng chức năng lưu vào bộ nhớ đệm HTTP, như trong mã mẫu sau:

Kotlin

val cacheDir = Context.getCacheDir()
val cacheSize = 10L * 1024L * 1024L // 10 MiB
val client: OkHttpClient = OkHttpClient.Builder()
    .cache(Cache(cacheDir, cacheSize))
    .build()

Java

File cacheDir = Context.getCacheDir();
long cacheSize = 10L * 1024L * 1024L; // 10 MiB
OkHttpClient client = new OkHttpClient.Builder()
    .cache(new Cache(cacheDir, cacheSize))
    .build();

Khi đã định cấu hình bộ nhớ đệm, bạn có thể phân phát các yêu cầu HTTP được lưu đầy đủ vào bộ nhớ đệm ngay từ bộ nhớ cục bộ mà không cần phải mở kết nối mạng. Phản hồi được lưu vào bộ nhớ đệm có điều kiện có thể xác thực độ mới của nội dung phản hồi từ máy chủ, giúp loại bỏ chi phí băng thông liên quan đến việc tải xuống. Phản hồi không được lưu vào bộ nhớ đệm sẽ được lưu trữ trong bộ nhớ đệm phản hồi cho các yêu cầu sau này.

Bạn có thể lưu dữ liệu không nhạy cảm vào bộ nhớ đệm trong thư mục bộ nhớ đệm bên ngoài không được quản lý bằng cách sử dụng Context.getExternalCacheDir(). Ngoài ra, bạn có thể lưu dữ liệu vào bộ nhớ đệm bảo mật, được quản lý bằng cách sử dụng Context.getCacheDir(). Xin lưu ý rằng bộ nhớ đệm trong này có thể bị xoá khi hệ thống sắp hết bộ nhớ trống.

Dùng kho lưu trữ

Để có phương pháp lưu vào bộ nhớ đệm phức tạp hơn, hãy cân nhắc mẫu thiết kế Kho lưu trữ. Trong đó có việc tạo một lớp tuỳ chỉnh, được gọi là Kho lưu trữ, cung cấp bản tóm tắt API trên một số dữ liệu hoặc tài nguyên cụ thể. Ban đầu, kho lưu trữ có thể tìm nạp dữ liệu từ nhiều nguồn, chẳng hạn như dịch vụ web từ xa, nhưng cung cấp cho phương thức gọi phiên bản dữ liệu đã lưu vào bộ nhớ đệm trong các lệnh gọi tiếp theo. Tầng gián tiếp này cho phép bạn cung cấp một chiến lược lưu vào bộ nhớ đệm mạnh mẽ, dành riêng cho ứng dụng của bạn. Để biết thêm thông tin về cách sử dụng mẫu Kho lưu trữ trong ứng dụng, hãy xem Hướng dẫn về cấu trúc ứng dụng.