Chọn một cơ sở dữ liệu: Cloud Firestore hoặc Cơ sở dữ liệu theo thời gian thực

Firebase cung cấp 2 cơ sở dữ liệu tài liệu dựa trên đám mây mà ứng dụng có thể truy cập. Khách hàng mới nên bắt đầu với Cloud Firestore:

  • Cloud Firestore là cơ sở dữ liệu tài liệu tương thích với JSON cấp doanh nghiệp được đề xuất và được hơn 600.000 nhà phát triển tin tưởng. Cơ sở dữ liệu này phù hợp với các ứng dụng có mô hình dữ liệu đa dạng thức, yêu cầu khả năng truy vấn, khả năng có thể mở rộng và khả năng hoạt động cao. Cơ sở dữ liệu này cũng cung cấp tính năng đồng bộ hoá ứng dụng có độ trễ thấp và quyền truy cập dữ liệu ngoại tuyến.

  • Realtime Database là cơ sở dữ liệu JSON cổ điển của Firebase. Cơ sở dữ liệu này phù hợp với các ứng dụng có mô hình dữ liệu đơn giản, yêu cầu khả năng tra cứu đơn giản và đồng bộ hoá có độ trễ thấp với khả năng mở rộng hạn chế.

Có những yếu tố quan trọng nào khác cần cân nhắc?

Sau khi cân nhắc các yếu tố quan trọng ở trên, bạn có thể đã sẵn sàng để chọn một cơ sở dữ liệu. Nếu bạn vẫn đang cân nhắc những ưu điểm và nhược điểm, thì phần này sẽ trình bày những điểm khác biệt khác giữa Cloud FirestoreRealtime Database.

Mô hình dữ liệu

Cả Realtime DatabaseCloud Firestore đều là Cơ sở dữ liệu NoSQL.

Cloud Firestore [ ƯU TIÊN ] Realtime Database
Lưu trữ dữ liệu dưới dạng bộ sưu tập tài liệu.
  • Dữ liệu đơn giản rất dễ lưu trữ trong tài liệu, tương tự như JSON.
  • Dữ liệu phân cấp phức tạp dễ dàng sắp xếp hơn ở quy mô lớn bằng cách sử dụng bộ sưu tập con trong tài liệu.
  • Yêu cầu ít quá trình khử chuẩn hoá và làm phẳng dữ liệu hơn.

Tìm hiểu thêm về mô hình dữ liệu Cloud Firestore.

Lưu trữ dữ liệu dưới dạng một cây JSON lớn.
  • Dữ liệu đơn giản rất dễ lưu trữ.
  • Dữ liệu phân cấp phức tạp khó sắp xếp hơn ở quy mô lớn.

Tìm hiểu thêm về mô hình dữ liệu Realtime Database.

Hỗ trợ theo thời gian thực và ngoại tuyến

Cả hai đều có SDK theo thời gian thực ưu tiên thiết bị di động và đều hỗ trợ lưu trữ dữ liệu tại địa phương cho các ứng dụng sẵn sàng hoạt động ngoại tuyến.

Cloud Firestore [ ƯU TIÊN ] Realtime Database
Hỗ trợ ngoại tuyến cho ứng dụng Apple, Android và ứng dụng web. Hỗ trợ ngoại tuyến cho ứng dụng Apple và Android.

Trạng thái hiện diện

Bạn có thể cần biết khi nào một ứng dụng đang trực tuyến hoặc ngoại tuyến. Firebase Realtime Database có thể ghi lại trạng thái kết nối của ứng dụng và cung cấp thông tin cập nhật mỗi khi trạng thái kết nối của ứng dụng thay đổi.

Cloud Firestore [ ƯU TIÊN ] Realtime Database
Không được hỗ trợ nguyên bản. Bạn có thể xây dựng dựa trên tính năng hỗ trợ trạng thái hiện diện của Realtime Database's bằng cách đồng bộ hoá Cloud FirestoreRealtime Database bằng Cloud Functions Hãy xem bài viết Xây dựng trạng thái hiện diện trong Cloud Firestore. Hỗ trợ trạng thái hiện diện.

Truy vấn

Truy xuất, sắp xếp và lọc dữ liệu từ một trong hai cơ sở dữ liệu thông qua các truy vấn.

Cloud Firestore [ ƯU TIÊN ] Realtime Database
Truy vấn được lập chỉ mục với tính năng lọc và sắp xếp tổng hợp .
  • Bạn có thể xâu chuỗi các bộ lọc và kết hợp tính năng lọc và sắp xếp trên một thuộc tính trong một truy vấn.
  • Truy vấn là truy vấn nông: chúng chỉ trả về tài liệu trong một bộ sưu tập hoặc nhóm bộ sưu tập cụ thể và không trả về dữ liệu bộ sưu tập con.
  • Truy vấn phải luôn trả về toàn bộ tài liệu.
  • Truy vấn được lập chỉ mục theo mặc định: Hiệu suất truy vấn tỷ lệ thuận với kích thước của tập kết quả, chứ không phải tập dữ liệu.
Truy vấn sâu với các tính năng lọc và sắp xếp hạn chế
  • Truy vấn có thể sắp xếp hoặc lọc trên một thuộc tính, nhưng không thể thực hiện cả hai.
  • Truy vấn là truy vấn sâu theo mặc định: chúng luôn trả về toàn bộ cây con.
  • Truy vấn có thể truy cập dữ liệu ở bất kỳ mức độ chi tiết nào, xuống đến các giá trị nút lá riêng lẻ trong cây JSON.
  • Truy vấn không yêu cầu chỉ mục; tuy nhiên, hiệu suất của một số truy vấn sẽ giảm khi tập dữ liệu của bạn tăng lên.

Thao tác ghi và giao dịch

Cloud Firestore [ ƯU TIÊN ] Realtime Database
Thao tác ghi và giao dịch nâng cao.
  • Thao tác ghi dữ liệu thông qua các thao tác đặt và cập nhật, cũng như các phép biến đổi nâng cao như toán tử mảng và toán tử số.
  • Giao dịch có thể đọc và ghi dữ liệu một cách nguyên tử từ bất kỳ phần nào của cơ sở dữ liệu.
Thao tác ghi và giao dịch cơ bản.
  • Ghi dữ liệu thông qua các thao tác đặt và cập nhật.
  • Giao dịch là nguyên tử trên một cây con dữ liệu cụ thể.

Độ tin cậy và hiệu suất

Cloud Firestore [ ƯU TIÊN ] Realtime Database
Cloud Firestore là một giải pháp khu vực và đa khu vực có khả năng tự động mở rộng quy mô.
  • Một giải pháp có độ trễ thấp, với thời gian phản hồi thông thường không quá 30 mili giây.
  • Lưu trữ dữ liệu của bạn trên nhiều trung tâm dữ liệu ở các khu vực riêng biệt, đảm bảo khả năng mở rộng quy mô trên toàn cầu và độ tin cậy cao.
  • Có sẵn ở các cấu hình khu vực hoặc đa khu vực trên khắp thế giới.
Đọc thêm về các đặc điểm hiệu suất và độ tin cậy Cloud Firestore trong Thỏa thuận mức độ cung cấp dịch vụ.
Realtime Database là một giải pháp khu vực.
  • Có sẵn ở các cấu hình khu vực. Cơ sở dữ liệu bị giới hạn ở khả năng hoạt động theo vùng trong một khu vực.
  • Độ trễ cực thấp, với thời gian phản hồi thông thường không quá 10 mili giây. Đây là lựa chọn lý tưởng để đồng bộ hoá trạng thái thường xuyên.
Đọc thêm về các đặc điểm hiệu suất và độ tin cậy Realtime Database trong Thỏa thuận mức độ cung cấp dịch vụ.

Thời gian hoạt động

Cloud Firestore [ ƯU TIÊN ] Realtime Database
Hiệu suất thời gian hoạt động cực cao.
  • Hiệu suất thời gian hoạt động thông thường là 99,999%.
  • Nếu khả năng hoạt động là yếu tố quan trọng nhất, chẳng hạn như trong các ứng dụng thương mại điện tử, hãy sử dụng Cloud Firestore.
Hiệu suất thời gian hoạt động cao.
  • Hiệu suất thời gian hoạt động thông thường là 99,95%.

Khả năng có thể mở rộng

Cloud Firestore [ ƯU TIÊN ] Realtime Database
Khả năng mở rộng là tự động.
  • Mở rộng quy mô hoàn toàn tự động. Không có giới hạn về số lượng kết nối đồng thời hoặc tốc độ ghi tổng thể vào cơ sở dữ liệu/giây.
  • giới hạn về tốc độ ghi vào từng tài liệu hoặc chỉ mục.
Khả năng mở rộng yêu cầu phân mảnh.
  • Mở rộng quy mô lên khoảng 200.000 kết nối đồng thời và 1.000 thao tác ghi/giây trong một cơ sở dữ liệu. Để mở rộng quy mô vượt quá mức đó, bạn cần phân mảnh dữ liệu trên nhiều cơ sở dữ liệu.
  • Không có giới hạn cục bộ về tốc độ ghi vào từng phần dữ liệu.

Bảo mật

Cloud Firestore [ ƯU TIÊN ] Realtime Database
Quy tắc không xếp tầng kết hợp tính năng uỷ quyền và xác thực.
  • Các thao tác đọc và ghi từ SDK di động được bảo mật bằng Cloud Firestore Security Rules.
  • Các thao tác đọc và ghi từ SDK máy chủ được bảo mật bằng tính năng Quản lý danh tính và quyền truy cập (IAM).
  • Quy tắc không xếp tầng trừ phi bạn sử dụng ký tự đại diện.
  • Quy tắc có thể hạn chế các truy vấn: Nếu kết quả của một truy vấn có thể chứa dữ liệu người dùng không có quyền truy cập, thì toàn bộ truy vấn sẽ không thành công.
Ngôn ngữ quy tắc xếp tầng tách biệt tính năng uỷ quyền và xác thực.

Giá

Cả hai giải pháp đều có trong các gói giá Spark và Blaze.

Cloud Firestore [ ƯU TIÊN ] Realtime Database
Tính phí chủ yếu dựa trên các thao tác được thực hiện trong cơ sở dữ liệu của bạn (đọc, ghi, xoá) và ở mức thấp hơn, băng thông và bộ nhớ.

Cloud Firestore hỗ trợ ngân sách và cảnh báo hằng tháng để tránh chi tiêu nhiều hơn mức bạn cảm thấy thoải mái.

Đọc thêm về Cloud Firestore các gói giá.

Chỉ tính phí băng thông và bộ nhớ, nhưng ở mức cao hơn rate.

Đọc thêm về Realtime Database các gói giá.

Sử dụng Cloud FirestoreRealtime Database

Bạn có thể sử dụng cả hai cơ sở dữ liệu trong cùng một ứng dụng hoặc dự án Firebase. Cả hai cơ sở dữ liệu NoSQL đều có thể lưu trữ cùng một loại dữ liệu và các thư viện ứng dụng hoạt động theo cách tương tự. Hãy lưu ý những điểm khác biệt đã nêu trước đó nếu bạn quyết định sử dụng cả hai cơ sở dữ liệu trong ứng dụng của mình.

Tìm hiểu thêm về các tính năng có trong cả Realtime DatabaseCloud Firestore.

Bạn đã sẵn sàng chọn một cơ sở dữ liệu?

Hy vọng rằng thông tin so sánh này đã giúp bạn quyết định chọn một giải pháp cơ sở dữ liệu Firebase. Giờ đây, bạn có thể tìm hiểu cách thêm cơ sở dữ liệu vào các dự án Firebase.