Tính năng ghi nhật ký trước khả năng tương thích cho các ứng dụng

Android 9 giới thiệu một chế độ đặc biệt của SQLiteDatabase có tên là Ghi trước khả năng tương thích (WAL). Chế độ này cho phép cơ sở dữ liệu sử dụng journal_mode=WAL trong khi vẫn duy trì hành vi giữ tối đa một kết nối cho mỗi cơ sở dữ liệu.

Theo mặc định, WAL tương thích được bật cho cơ sở dữ liệu của ứng dụng, trừ phi ứng dụng có:

  1. Chọn sử dụng hoặc không sử dụng tính năng ghi nhật ký trước bằng cách gọi SQLiteDatabase.enableWriteAheadLogging hoặc disableWriteAheadLogging
  2. Yêu cầu rõ ràng chế độ nhật ký bằng cách gọi SQLiteDatabase.OpenParams.setJournalMode(String mode)

Việc bật chế độ nhật ký WAL có thể giúp cải thiện đáng kể hiệu suất và giảm lượng dữ liệu ghi. Ví dụ: trên hệ thống tệp ext4, WAL có thể giúp cải thiện tốc độ ghi gấp 4 lần.

Khả năng tương thích WAL được bật theo mặc định và không yêu cầu triển khai thêm.

Tắt WAL tương thích

Để tắt chế độ WAL tương thích, hãy phủ tài nguyên cấu hình db_compatibility_wal_supported.

Ví dụ:

<bool name="db_compatibility_wal_supported">false</bool>

Bạn nên tắt WAL tương thích cho các cấu hình mà chế độ nhật ký WAL không mang lại lợi thế về hiệu suất so với các chế độ nhật ký rollback truyền thống. Ví dụ: trên hệ thống tệp F2FS, mặc dù SQLite hỗ trợ ghi nguyên tử và hiệu suất nhật ký DELETE tương tự như WAL, nhưng WAL có thể tăng số lượng ghi từ 10% đến 15%.

Xác nhận kết quả

Để xác thực chế độ WAL tương thích, hãy chạy các kiểm thử CTS từ mô-đun CtsDatabaseTestCases. Các bài kiểm thử CTS sẽ xác minh hành vi dự kiến khi bật Compatibility WAL.