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 hai cơ sở dữ liệu tài liệu trên đám mây và ứng dụng khách có thể truy cập vào. T4 đề xuất khách hàng mới bắt đầu bằng Cloud Firestore:

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

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

Một số điều quan trọng khác cần lưu ý là gì?

Sau khi cân nhắc những yếu tố chính trước đó, 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 các ưu và nhược điểm, phần này đề cập đến các sự khác biệt 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 tập hợp tài liệu.
  • Dữ liệu đơn giản rất dễ lưu trữ trong các tài liệu, rất giống với JSON.
  • Dữ liệu phân cấp, phức tạp dễ sắp xếp hơn trên quy mô lớn bằng cách sử dụng các tập hợp con trong tài liệu.
  • Yêu cầu ít chuẩn hoá và làm phẳng dữ liệu hơn.

Tìm hiểu thêm về chính sách 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ức tạp và có thứ bậc khó sắp xếp trên quy mô lớn.

Tìm hiểu thêm về chính sách 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 ưu tiên thiết bị di động, theo thời gian thực và cả hai đều hỗ trợ lưu trữ dữ liệu cục bộ cho ứng dụng có chế độ ngoại tuyến.

Cloud Firestore Ưu tiên Realtime Database
Hỗ trợ ngoại tuyến cho các ứng dụng khách của Apple, Android và 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ể biết được thời điểm ứng dụng khách đ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 máy khách 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ợ sẵn. Bạn có thể xây dựng dựa trênRealtime Database hỗ trợ sự hiện diện bằng cách đồng bộ hoá Cloud FirestoreRealtime Database thông qua Cloud Functions Xem phần Bản dựng hiện diện trong Cloud Firestore. Hỗ trợ tính năng 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 có kết hợp sắp xếp và lọc.
  • Bạn có thể liên kết các bộ lọc cũng như kết hợp tính năng lọc và sắp xếp trên một tài sản trong một truy vấn.
  • Truy vấn nông: chúng chỉ trả về tài liệu trong một tập hợp cụ thể hoặc nhóm bộ sưu tập 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.
  • Các 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 có các tính năng sắp xếp và lọc bị hạn chế.
  • Các truy vấn chỉ có thể sắp xếp hoặc lọc theo một tài sản, nhưng không thể lọc cả hai.
  • Theo mặc định, các truy vấn sẽ truy vấn sâu: chúng luôn trả về toàn bộ cây con.
  • Các truy vấn có thể truy cập vào dữ liệu ở mọi mức độ chi tiết, đến từng giá trị nút lá trong cây JSON.
  • Các 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 nhất định sẽ giảm khi tập dữ liệu của bạn tăng lên.

Hoạt động ghi và giao dịch

Cloud Firestore Ưu tiên Realtime Database
Các thao tác ghi và giao dịch nâng cao.
  • Ghi các thao tác 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ử số và mảng.
  • Giao dịch có thể đọc và ghi dữ liệu từng phần từ bất kỳ phần nào của cơ sở dữ liệu.
Các 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 mang tính 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 theo khu vực và nhiều khu vực có khả năng mở rộng tự động.
  • Giải pháp độ 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 trên toàn cầu và tính ổn định cao.
  • Được cung cấp trong cấu hình theo khu vực hoặc nhiều khu vực trên khắp thế giới.
Đọc thêm về các đặc điểm của Cloud Firestore về hiệu suất và độ tin cậy trong Thoả thuận mức dịch vụ.
Realtime Database là một giải pháp theo khu vực.
  • Có trong cấu hình theo khu vực. Cơ sở dữ liệu chỉ được cung cấp theo vùng tình trạng còn hà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 lớn hơn 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 của Realtime Database về hiệu suất và độ tin cậy trong Thoả thuận mức 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 tình trạng còn hàng là vô cùng quan trọng, chẳng hạn như trong ứng dụng thương mại điện tử, 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 điển hình là 99,95%.

Khả năng mở rộng

Cloud Firestore Ưu tiên Realtime Database
Tự động chuyển tỷ lệ.
  • Điều chỉnh tỷ lệ hoàn toàn tự động. Giới hạn mở rộng là khoảng 1 triệu kết nối đồng thời và 10.000 lượt ghi/giây. Chúng tôi dự định sẽ tăng các giới hạn này trong tương lai.
  • giới hạn về tốc độ ghi đối với từng tài liệu hoặc chỉ mục.
Việc mở rộng quy mô yêu cầu phân đoạn.
  • Mở rộng quy mô lên khoảng 200.000 kết nối đồng thời và 1.000 lượt ghi/giây trong một cơ sở dữ liệu. Việc mở rộng quy mô ra ngoài phạm vi đó đòi hỏi phải phân đoạn dữ liệu của bạn trên nhiều cơ sở dữ liệu.
  • Không có giới hạn cục bộ về tốc độ ghi cho từng phần dữ liệu.

Bảo mật

Cloud Firestore Ưu tiên Realtime Database
Quy tắc không phân tầng kết hợp việc uỷ quyền và xác thực.
  • Đọc và ghi từ SDK di động được bảo mật bằng Cloud Firestore Security Rules.
  • Đọc và ghi từ các 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 phân tầng trừ phi bạn sử dụng ký tự đại diện.
  • Quy tắc có thể ràng buộc truy vấn: Nếu kết quả của truy vấn có thể chứa dữ liệu người dùng không có quyền truy cập vào thì toàn bộ truy vấn sẽ không thành công.
Ngôn ngữ quy tắc xếp chồng phân tách việc uỷ quyền và xác thực.

Giá

Cả hai giải pháp này đều có trên Gói giá Spark và linh hoạt.

Cloud Firestore Ưu tiên Realtime Database
Tính phí chủ yếu cho các hoạt động được thực hiện trong cơ sở dữ liệu của bạn (đọc, ghi, xoá) và ở tốc độ, băng thông và bộ nhớ thấp hơn.

Cloud Firestore hỗ trợ hằng ngày hạn mức chi tiêu cho App Engine dự án, để đảm bảo bạn không vượt quá chi phí đang cảm thấy thoải mái.

Đọc thêm về Gói giá của Cloud Firestore.

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

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

Đang 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ả NoSQL cơ sở dữ liệu có thể lưu trữ cùng loại dữ liệu và thư viện ứng dụng hoạt động trong một theo cách tương tự. Hãy lưu ý đến những khác biệt đã nêu trước đó nếu bạn quyết định để 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 cơ sở dữ liệu chưa?

Hy vọng thông tin so sánh này đã giúp bạn chọn được giải pháp cơ sở dữ liệu Firebase. Bây giờ, bạn có thể tìm hiểu cách thêm cơ sở dữ liệu vào dự án Firebase của mình.