Trang này mô tả cách sử dụng bảng điều khiển Google Cloud và Google Cloud CLI để định cấu hình chính sách thời gian tồn tại (TTL). Trước khi đọc trang này, bạn nên hiểu rõ mô hình dữ liệu Cloud Firestore.
Tổng quan về thời gian hoạt động
Sử dụng chính sách TTL để tự động xoá dữ liệu cũ khỏi cơ sở dữ liệu. Chính sách TTL chỉ định một trường nhất định làm thời gian hết hạn cho các tài liệu trong một nhóm bộ sưu tập nhất định. Với TTL, bạn có thể giảm chi phí lưu trữ bằng cách xoá dữ liệu lỗi thời. Dữ liệu thường bị xoá trong vòng 24 giờ sau ngày hết hạn.
Giá
Các thao tác xoá TTL được tính vào chi phí xoá tài liệu. Để biết giá của các thao tác xoá, hãy xem phần Giá của Cloud Firestore.
Giới hạn và quy tắc ràng buộc
- Bạn chỉ có thể đánh dấu một trường trong mỗi nhóm tập hợp là trường TTL.
- Tổng cộng bạn được phép có 200 cấu hình cấp trường. Một cấu hình trường có thể chứa nhiều cấu hình cho cùng một trường. Ví dụ: một trường hợp miễn trừ lập chỉ mục một trường và một chính sách TTL trên cùng một trường được tính là một cấu hình trường đối với giới hạn.
- Đối với khách hàng sử dụng Firestore ở chế độ Datastore, bạn không thể sử dụng TTL với chế độ đồng thời là Optimistic With Entity Groups (Tự tin với nhóm thực thể). Cân nhắc thay đổi chế độ đồng thời thành Chế độ đồng thời lạc quan.
Xoá TTL
Hãy lưu ý những hành vi chính sau đây của việc xoá do TTL điều khiển:
Quá trình xoá thông qua TTL không diễn ra ngay lập tức. Các tài liệu đã hết hạn sẽ tiếp tục xuất hiện trong các truy vấn và yêu cầu tra cứu cho đến khi quy trình TTL thực sự xoá các tài liệu đó. TTL giúp xoá giao dịch kịp thời để giảm tổng chi phí sở hữu cho các giao dịch xoá. Dữ liệu thường bị xoá trong vòng 24 giờ sau ngày hết hạn.
Việc xoá một tài liệu thông qua TTL sẽ không xoá các bộ sưu tập con trong tài liệu đó.
Việc áp dụng chính sách TTL cho một nhóm thu thập hiện có sẽ dẫn đến việc xoá hàng loạt tất cả dữ liệu đã hết hạn theo chính sách TTL mới. Xin lưu ý rằng việc xoá hàng loạt này cũng không diễn ra tức thì và phụ thuộc vào lượng dữ liệu hiện có cho nhóm bộ sưu tập đó.
Nếu một tài liệu đã có thời gian hết hạn và bạn thêm chính sách TTL mới vào tập hợp, thì tài liệu đó sẽ bị xoá trong vòng 24 giờ kể từ khi chính sách TTL hoàn tất quá trình thiết lập và có hiệu lực.
TTL không nhất thiết phải xoá các tài liệu theo thứ tự giống với dấu thời gian hết hạn của các tài liệu đó.
Việc xoá không được thực hiện theo giao dịch. Các tài liệu có cùng thời gian hết hạn không nhất thiết phải bị xoá cùng một lúc. Nếu bạn yêu cầu hành vi này, hãy thực hiện việc xoá bằng thư viện ứng dụng.
Cloud Firestore sẽ luôn tuân theo trường TTL mới nhất để xác định thời gian hết hạn. Ví dụ: nếu một tài liệu đã hết hạn nhưng chưa bị xoá có trường TTL được cập nhật thành một ngày sau đó, thì tài liệu đó sẽ không hết hạn và ngày mới sẽ được sử dụng.
TTL được thiết kế để giảm thiểu tác động đến các hoạt động khác trong cơ sở dữ liệu. Các lượt xoá do TTL điều khiển sẽ được xử lý với mức độ ưu tiên thấp hơn. Chúng tôi cũng áp dụng các chiến lược khác để làm giảm sự gia tăng đột biến về lưu lượng truy cập do các lượt xoá do TTL điều khiển.
Thao tác xoá thông qua TTL sẽ gọi tất cả trình nghe ảnh chụp nhanh đang hoạt động và kích hoạt trình kích hoạt Cloud Functions Cloud Firestore.
Trường và chỉ mục TTL
Trường TTL có thể được lập chỉ mục hoặc không được lập chỉ mục. Tuy nhiên, vì trường TTL là một dấu thời gian, nên việc lập chỉ mục trường này có thể ảnh hưởng đến hiệu suất ở tốc độ lưu lượng truy cập cao hơn. Việc lập chỉ mục trường dấu thời gian có thể tạo ra điểm nóng, điều này trái với các phương pháp hay nhất. Điểm nóng là tỷ lệ đọc, ghi và xoá cao đối với một phạm vi tài liệu hẹp.
Theo mặc định, Cloud Firestore tạo một chỉ mục trường duy nhất cho tất cả các trường. Bạn có thể tạo trường miễn trừ chỉ mục đơn để tắt chỉ mục trên trường TTL.
Quyền
Để định cấu hình chính sách TTL, bạn cần có quyền sau trong dự án:
- Để xem chính sách TTL, bạn cần có quyền
datastore.indexes.list
vàdatastore.indexes.get
. - Bạn cần có quyền
datastore.indexes.update
để sửa đổi chính sách TTL. - Bạn cần có
datastore.operations.list
vàdatastore.operations.get
để kiểm tra trạng thái của các thao tác TTL.
Đối với các vai trò chỉ định những quyền này, hãy xem Vai trò quản lý quyền truy cập và danh tính Cloud Firestore.
Trước khi bắt đầu
Trước khi sử dụng CLI gcloud để quản lý chính sách TTL, hãy sử dụng lệnh gcloud components update
để cập nhật các thành phần lên phiên bản mới nhất hiện có:
gcloud components update
Tạo chính sách TTL
Khi tạo chính sách TTL, bạn chỉ định một trường tài liệu làm thời gian hết hạn cho tài liệu trong một nhóm bộ sưu tập.
TTL sử dụng một trường được chỉ định để xác định những tài liệu đủ điều kiện để xoá.
Trường TTL này phải thuộc loại Date and time
. Bạn có thể chọn một trường đã tồn tại hoặc chỉ định một trường mà bạn dự định thêm sau.
Hãy cân nhắc những điều sau trước khi bạn đặt giá trị trường TTL:
Giá trị trường TTL có thể là thời gian trong tương lai, hiện tại hoặc quá khứ. Nếu giá trị là một thời gian trong quá khứ, thì tài liệu đó sẽ đủ điều kiện để xoá ngay lập tức. Ví dụ: bạn có thể tạo chính sách TTL bằng trường
expireAt
, sau đó thêm chính sách này vào các tài liệu hiện có.Việc sử dụng bất kỳ loại dữ liệu nào khác hoặc không đặt giá trị trường TTL sẽ vô hiệu hoá TTL cho từng tài liệu.
Để tạo chính sách TTL, hãy làm theo các bước sau:
Bảng điều khiển Google Cloud
Trong Google Cloud Console, hãy chuyển đến trang Databases (Cơ sở dữ liệu).
Chọn cơ sở dữ liệu cần thiết trong danh sách cơ sở dữ liệu.
Trong trình đơn điều hướng, hãy nhấp vào Thời gian tồn tại.
Nhấp vào Tạo chính sách.
Nhập tên nhóm bộ sưu tập và tên trường dấu thời gian.
Nhấp vào Tạo.
Bảng điều khiển sẽ quay lại trang Thời gian tồn tại. Nếu thao tác bắt đầu thành công, trang sẽ thêm một mục vào bảng chính sách TTL. Nếu không thành công, trang sẽ hiển thị thông báo lỗi.
gcloud
Sử dụng lệnh firestore fields ttls
update
để định cấu hình chính sách TTL. Thêm cờ --async
để ngăn giao diện dòng lệnh gcloud chờ thao tác hoàn tất.
gcloud firestore fields ttls update ttl_field --collection-group=collection_group_name --enable-ttl
Thời lượng bật chính sách TTL
Ngay cả trên cơ sở dữ liệu trống, bạn cũng có thể mất từ 10 phút trở lên để bật chính sách TTL. Sau khi bạn bắt đầu một thao tác, việc đóng thiết bị đầu cuối sẽ không huỷ thao tác đó.
Xem chính sách TTL
Để xem chính sách TTL và trạng thái của các chính sách đó, hãy làm theo các bước sau:
Bảng điều khiển Google Cloud
Trong Google Cloud Console, hãy chuyển đến trang Databases (Cơ sở dữ liệu).
Chọn cơ sở dữ liệu cần thiết trong danh sách cơ sở dữ liệu.
Trong trình đơn điều hướng, hãy nhấp vào Thời gian tồn tại.
Bảng điều khiển liệt kê các chính sách TTL cho cơ sở dữ liệu của bạn và bao gồm trạng thái của từng chính sách.
gcloud
Sử dụng lệnh firestore fields ttls list
để định cấu hình chính sách TTL. Lệnh sau đây liệt kê tất cả các chính sách TTL.
gcloud firestore fields ttls list
Để liệt kê các chính sách TTL trong một nhóm bộ sưu tập cụ thể, hãy sử dụng nội dung sau:
gcloud firestore fields ttls list --collection-group=collection_group_name
Xem thông tin chi tiết về thao tác
Bạn có thể sử dụng CLI gcloud để xem thêm thông tin chi tiết về chính sách TTL ở trạng thái CREATING
.
Sử dụng lệnh operations list
để xem tất cả các thao tác đang chạy và mới hoàn tất:
gcloud firestore operations list
Phản hồi bao gồm thông tin ước tính về tiến trình của thao tác.
Tắt chính sách TTL
Để tắt chính sách TTL, hãy làm theo các bước sau:
Bảng điều khiển Google Cloud
Trong Google Cloud Console, hãy chuyển đến trang Databases (Cơ sở dữ liệu).
Chọn cơ sở dữ liệu cần thiết trong danh sách cơ sở dữ liệu.
Trong trình đơn điều hướng, hãy nhấp vào Thời gian tồn tại.
Trong bảng Chính sách TTL, hãy tìm hàng cho chính sách TTL. Trong hàng bảng này, hãy nhấp vào nút Delete (xoá) (biểu tượng thùng rác).
Xác nhận bằng cách nhấp vào Xoá.
Bảng điều khiển sẽ quay lại trang Thời gian tồn tại. Nếu thành công, Cloud Firestore sẽ xoá chính sách TTL khỏi bảng.
gcloud
1. Sử dụng lệnh firestore fields ttls update
để định cấu hình chính sách TTL. Thêm cờ --async
để ngăn giao diện dòng lệnh gcloud chờ thao tác hoàn tất.
gcloud firestore fields ttls update ttl_field --collection-group=collection_group_name --disable-ttl
Theo dõi việc xoá TTL
Bạn có thể sử dụng Cloud Monitoring để xem các chỉ số về việc xoá do TTL. Cloud Firestore cung cấp các chỉ số sau đây cho TTL:
Loại chỉ số | Tên chỉ số | Nội dung mô tả chỉ số |
---|---|---|
firestore.googleapis.com/document/ttl_deletion_count | Số lượt xoá theo thời gian tồn tại |
Tổng số tài liệu bị xoá theo chính sách TTL. |
firestore.googleapis.com/document/ttl_expiration_to_deletion_delays | Thời gian trễ từ khi hết hạn thời gian lưu trữ đến khi xoá |
Khoảng thời gian trôi qua giữa thời điểm một tài liệu hết hạn theo chính sách TTL và thời điểm tài liệu đó thực sự bị xoá. |
Để thiết lập trang tổng quan có các chỉ số Cloud Firestore, hãy xem phần quản lý trang tổng quan tuỳ chỉnh và thêm tiện ích trang tổng quan.