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 sử dụng Cloud Firestore:

  • Cloud Firestore là một giải pháp nên tương thích với JSON cấp doanh nghiệp đượ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.

  • Cơ sở dữ liệu theo thời gian thực 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 cần cân nhắc trước đó, bạn có thể sẵn sàng chọn 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 Firestore và Cơ sở dữ liệu theo thời gian thực.

Mô hình dữ liệu

Cả Cơ sở dữ liệu theo thời gian thực và Cloud Firestore đều là Cơ sở dữ liệu NoSQL.

Cloud Firestore ưu tiên Cơ sở dữ liệu theo thời gian thực
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 của 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 của Cơ sở dữ liệu theo thời gian thực.

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 Cơ sở dữ liệu theo thời gian thực
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 các ứng dụng Apple và Android.

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

Việc biết thời điểm khách hàng ở trên mạng hay ngoại tuyến có thể hữu ích. Firebase Cơ sở dữ liệu theo thời gian thực 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 Cơ sở dữ liệu theo thời gian thực
Không được hỗ trợ sẵn. Bạn có thể tạo bản dựng dựa trên Cơ sở dữ liệu theo thời gian thực hỗ trợ sự hiện diện bằng cách đồng bộ hoá Cloud Firestore và Cơ sở dữ liệu theo thời gian thực thông qua Chức năng đám mây Xem phần Bản dựng 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 Cơ sở dữ liệu theo thời gian thực
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.
  • 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 hợp kết quả, chứ không phải của tập dữ liệu.
Truy vấn sâu có giới hạn tính năng sắp xếp và lọc.
  • 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.
  • Các truy vấn có định dạng sâu theo mặc định: 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.
  • 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ẽ suy giảm khi tập dữ liệu phát triển.

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

Cloud Firestore ưu tiên Cơ sở dữ liệu theo thời gian thực
Các thao tác ghi và giao dịch nâng cao.
  • Ghi thao tác dữ liệu thông qua thao tác thiết lập và cập nhật cũng như các phép biến đổi nâng cao như các toán tử mảng và số.
  • 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 thiết lập 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 Cơ sở dữ liệu theo thời gian thực
Cloud Firestore là một giải pháp đa khu vực, đa khu vực và có thể mở rộng quy mô 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 các đặc điểm về hiệu suất và độ tin cậy của Cloud Firestore trong Thỏa thuận mức dịch vụ.
Cơ sở dữ liệu theo thời gian thực 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. Một lựa chọn lý tưởng để thường xuyên đồng bộ hoá trạng thái.
Đọc thêm về các đặc điểm về hiệu suất và độ tin cậy của Cơ sở dữ liệu theo thời gian thực trong Thỏa thuận mức dịch vụ.

Thời gian hoạt động

Cloud Firestore ưu tiên Cơ sở dữ liệu theo thời gian thực
Hiệu suất thời gian hoạt động cực kỳ cao.
  • Hiệu suất thời gian hoạt động điển hình 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 Cơ sở dữ liệu theo thời gian thực
Tự động chuyển tỷ lệ.
  • Điều chỉnh tỷ lệ hoàn toàn tự động. Sắp hết giới hạn tỷ lệ 1 triệu kết nối đồng thời và 10.000 ghi/giây. Chúng tôi dự định 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 lên tới khoảng 200.000 kết nối đồng thời và 1.000 lần ghi/giây một cơ sở dữ liệu duy nhất. 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 Cơ sở dữ liệu theo thời gian thực
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 Quy tắc bảo mật của Cloud Firestore.
  • Đọc và ghi từ các SDK máy chủ được bảo mật bằ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 Cơ sở dữ liệu theo thời gian thực
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 các dự án App Engine, để đảm bảo bạn không vượt quá chi phí cảm thấy thoải mái.

Đọc thêm về Các 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ề Gói giá của Cơ sở dữ liệu theo thời gian thực.

Sử dụng Cloud Firestore và Cơ sở dữ liệu theo thời gian thực

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ả Cơ sở dữ liệu theo thời gian thựcCloud Firestore.

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

Hy vọng rằng phép so sánh này đã giúp bạn giải quyết được vấn đề về 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.