Mở rộng quy mô với nhiều cơ sở dữ liệu

Cách tốt nhất để tối ưu hoá hiệu suất và mở rộng quy mô dữ liệu trong Firebase Realtime Database là chia dữ liệu trên nhiều thực thể Realtime Database, còn gọi là phân đoạn cơ sở dữ liệu. Tính năng phân đoạn giúp bạn linh hoạt mở rộng quy mô ra ngoài phạm vi giới hạn áp dụng cho từng cơ sở dữ liệu phiên bản mới nhất, ngoài việc cân bằng tải và tối ưu hoá hiệu suất.

Thời điểm phân đoạn dữ liệu của bạn

Bạn có thể muốn phân đoạn dữ liệu của mình trên nhiều cơ sở dữ liệu nếu bạn đang sử dụng Realtime Database và phù hợp với bất kỳ trường hợp nào sau đây:

  • Bạn muốn mở rộng quy mô ra ngoài giới hạn 200.000 kết nối cùng lúc, 1.000 thao tác ghi/giây hoặc bất kỳ thao tác nào khác giới hạn cho một thực thể cơ sở dữ liệu.
  • Bạn có nhiều tập dữ liệu riêng biệt và muốn tối ưu hoá hiệu suất (ví dụ: ứng dụng trò chuyện phân phát cho các nhóm người dùng riêng biệt, độc lập).
  • Bạn muốn cân bằng tải trên nhiều cơ sở dữ liệu để cải thiện thời gian hoạt động và giảm nguy cơ tải quá nhiều phiên bản cơ sở dữ liệu.

Cách phân đoạn dữ liệu của bạn

Để phân đoạn dữ liệu của bạn, hãy làm theo các bước sau (được mô tả chi tiết hơn dưới đây):

  1. Liên kết dữ liệu của bạn với nhiều cơ sở dữ liệu theo nhu cầu cụ thể của ứng dụng.
  2. Tạo nhiều thực thể cơ sở dữ liệu.
  3. Định cấu hình ứng dụng của bạn để ứng dụng kết nối với thực thể Realtime Database cần thiết cho từng tập dữ liệu.

Liên kết dữ liệu

Khi bạn ánh xạ dữ liệu của mình đến nhiều cơ sở dữ liệu, hãy cố gắng đáp ứng các điều kiện sau:

  • Mỗi truy vấn chỉ chạy trên một thực thể cơ sở dữ liệu duy nhất. Realtime Database không hỗ trợ truy vấn trên các thực thể cơ sở dữ liệu.
  • Không chia sẻ hoặc sao chép dữ liệu giữa các thực thể cơ sở dữ liệu (hoặc giảm thiểu tình trạng chia sẻ hay trùng lặp).
  • Mỗi phiên bản ứng dụng chỉ kết nối với một cơ sở dữ liệu tại một thời điểm bất kỳ.

Khi bạn liên kết dữ liệu của mình, hãy xem xét áp dụng các chiến lược sau:

Tạo "mảnh chính"

Lưu trữ bản đồ về cách dữ liệu của bạn được lưu trữ trên thực thể cơ sở dữ liệu. Bằng cách này, bạn có thể lập trình để tra cứu cơ sở dữ liệu nào thực thể tương ứng với ứng dụng đang kết nối. Xin lưu ý rằng thao tác này có thể sẽ tốn nhiều chi phí hơn so với việc kết nối trực tiếp với cơ sở dữ liệu cụ thể thông tin vị trí vào đúng lúc.

Nhóm dữ liệu theo danh mục hoặc theo khách hàng

Lưu trữ dữ liệu trong các thực thể cơ sở dữ liệu riêng biệt, được nhóm theo người dùng hoặc loại dữ liệu. Ví dụ: nếu bạn xây dựng một ứng dụng trò chuyện dành cho nhiều tổ chức, bạn có thể tạo một thực thể cơ sở dữ liệu cho mỗi tổ chức và lưu trữ toàn bộ nội dung trò chuyện trong các thực thể cơ sở dữ liệu duy nhất.

Trong trường hợp này, tổ chức A và tổ chức B không chia sẻ dữ liệu, không có dữ liệu trùng lặp nào trong cơ sở dữ liệu của bạn và bạn chỉ thực hiện truy vấn trên một thực thể cơ sở dữ liệu. Ngoài ra, người dùng trong mỗi tổ chức chỉ kết nối với cơ sở dữ liệu của tổ chức khi họ sử dụng ứng dụng trò chuyện.

Sau đó, bạn có thể tạo trước một số thực thể cơ sở dữ liệu và sử dụng mã của tổ chức để liên kết một nhóm với thực thể cơ sở dữ liệu của tổ chức đó. Ví dụ: tổ chức A liên kết với Cơ sở dữ liệu theo thời gian thực A.

Cách bạn ánh xạ dữ liệu cho ứng dụng phụ thuộc vào trường hợp sử dụng cụ thể của bạn, nhưng các điều kiện và chiến lược được nêu ở trên có thể giúp bạn xác định những gì phù hợp cho .

Tạo nhiều thực thể Realtime Database

Nếu đang sử dụng Gói giá linh hoạt, bạn có thể tạo tối đa 1.000 thực thể cơ sở dữ liệu trong cùng một dự án Firebase.

tạo cơ sở dữ liệu trong <span class=Bảng điều khiển của Firebase với trình đơn theo bối cảnh trong mục cơ sở dữ liệu" >

  1. Trong bảng điều khiển của Firebase, hãy chuyển đến thẻ Dữ liệu trong Phát triển > Cơ sở dữ liệu .
  2. Chọn Tạo cơ sở dữ liệu mới trên trình đơn trong mục Realtime Database.
  3. Tuỳ chỉnh tài liệu tham khảo về Cơ sở dữ liệuQuy tắc bảo mật, rồi nhấp vào Đã hiểu .

Lặp lại quá trình này để tạo số lượng thực thể cơ sở dữ liệu tuỳ ý. Một thực thể cơ sở dữ liệu có tập hợp Firebase Realtime Database Security Rules riêng, vì vậy, bạn có thể tinh chỉnh quyền truy cập vào dữ liệu.

Bạn có thể tạo và quản lý các phiên bản cơ sở dữ liệu trong bảng điều khiển Firebase hoặc sử dụng API REST Quản lý cơ sở dữ liệu theo thời gian thực.

Chỉnh sửa và triển khai Realtime Database Security Rules cho từng thực thể

Hãy đảm bảo rằng Realtime Database Security Rules của bạn cấp quyền truy cập thích hợp vào từng ứng dụng thực thể của cơ sở dữ liệu trong dự án. Mỗi cơ sở dữ liệu có một bộ quy tắc riêng, mà bạn có thể chỉnh sửa và triển khai từ bảng điều khiển Firebase hoặc sử dụng Firebase Giao diện dòng lệnh (CLI) để triển khai các mục tiêu.

  • Để chỉnh sửa và triển khai quy tắc từ bảng điều khiển Firebase, hãy làm theo các bước sau:

    1. Chuyển đến Thẻ Quy tắc trong phần Phát triển > Cơ sở dữ liệu.
    2. Chọn cơ sở dữ liệu bạn muốn chỉnh sửa, sau đó sửa đổi các quy tắc.
  • Để chỉnh sửa và triển khai quy tắc từ Giao diện dòng lệnh (CLI) Firebase, hãy làm theo các bước sau:

    1. Sửa đổi quy tắc trong tệp quy tắc cho các thực thể cơ sở dữ liệu (ví dụ: foo.rules.json).
    2. Tạo và áp dụng các mục tiêu triển khai để liên kết những cơ sở dữ liệu sử dụng cùng một tệp quy tắc. Ví dụ:
      firebase target:apply database main my-db-1 my-db-2
      firebase target:apply database other my-other-db-3
    3. Cập nhật tệp cấu hình firebase.json bằng các mục tiêu triển khai:

      {
        "database": [
          {"target": "main", "rules": "foo.rules.json"},
          {"target": "other", "rules": "bar.rules.json"}
        ]
      }
      
    4. Chạy lệnh triển khai:

      firebase deploy

Đảm bảo bạn thường xuyên chỉnh sửa và triển khai các quy tắc từ cùng một nơi. Triển khai các quy tắc từ CLI Firebase sẽ ghi đè mọi chỉnh sửa mà bạn đã thực hiện trong Bảng điều khiển của Firebase và việc chỉnh sửa các quy tắc ngay trong bảng điều khiển của Firebase ghi đè mọi thay đổi gần đây mà bạn đã triển khai thông qua CLI Firebase.

Kết nối ứng dụng của bạn với nhiều phiên bản cơ sở dữ liệu

Sử dụng tham chiếu cơ sở dữ liệu để truy cập dữ liệu được lưu trữ trong các thực thể cơ sở dữ liệu phụ. Bạn có thể lấy thông tin tham chiếu cho một phiên bản cơ sở dữ liệu cụ thể theo URL hoặc ứng dụng. Nếu nếu không chỉ định URL, bạn sẽ nhận được tham chiếu cho thực thể cơ sở dữ liệu mặc định.

Web

import { initializeApp } from "firebase/app";
import { getDatabase } from "firebase/database";

const app1 = initializeApp({
  databaseURL: "https://testapp-1234-1.firebaseio.com"
});

const app2 = initializeApp({
  databaseURL: "https://testapp-1234-2.firebaseio.com"
}, 'app2');

// Get the default database instance for an app1
const database1 = getDatabase(app1);

// Get a database instance for app2
const database2 = getDatabase(app2);

Web

const app1 = firebase.initializeApp({
  databaseURL: "https://testapp-1234-1.firebaseio.com"
});

const app2 = firebase.initializeApp({
  databaseURL: "https://testapp-1234-2.firebaseio.com"
}, 'app2');

// Get the default database instance for an app1
var database1 = firebase.database();

// Get a database instance for app2
var database2 = firebase.database(app2);
Swift
Lưu ý: Sản phẩm Firebase này không dùng được trên mục tiêu App Clip (Đoạn video ứng dụng).
// Get the default database instance for an app
var ref: DatabaseReference!

ref = Database.database().reference()
// Tải phiên bản cơ sở dữ liệu phụ theo URL var ref: DatabaseReference! ref = Database.database("https://testapp-1234.firebaseio.com").reference()
Objective-C
Lưu ý: Sản phẩm Firebase này không dùng được trên mục tiêu App Clip (Đoạn video ứng dụng).
// Get the default database instance for an app
@property (strong, nonatomic) FIRDatabaseReference *ref;

self.ref = [[FIRDatabase database] reference];
// Tải phiên bản cơ sở dữ liệu phụ theo URL @thuộc tính (strong, không nguyên tử) FIRDatabaseReference *ref; Self.ref = [[FIRDatabase DatabaseWithURL:@"https://testapp-1234.firebaseio.com"] tham chiếu];

Kotlin+KTX

// Get the default database instance for an app
val primary = Firebase.database.reference

// Get a secondary database instance by URL
val secondary = Firebase.database("https://testapp-1234.firebaseio.com").reference

Java

// Get the default database instance for an app
DatabaseReference primary = FirebaseDatabase.getInstance()
        .getReference();

// Get a secondary database instance by URL
DatabaseReference secondary = FirebaseDatabase.getInstance("https://testapp-1234.firebaseio.com")
        .getReference();

Chỉ định một thực thể khi sử dụng Giao diện dòng lệnh (CLI) của Firebase

Sử dụng tuỳ chọn --instance để chỉ định Firebase Realtime Database mà bạn muốn hãy áp dụng lệnh CLI của Firebase. Ví dụ: sử dụng lệnh sau để chạy trình phân tích tài nguyên cho một thực thể cơ sở dữ liệu có tên my-example-shard.firebaseio.com:

firebase database:profile --instance "my-example-shard"

Tối ưu hoá các kết nối trên từng cơ sở dữ liệu

Nếu mỗi ứng dụng cần kết nối với nhiều cơ sở dữ liệu trong một phiên hoạt động, bạn có thể giảm số lượng kết nối đồng thời đến từng thực thể cơ sở dữ liệu bằng cách kết nối với từng phiên bản cơ sở dữ liệu khi cần thiết.

Xem thêm lời khuyên

Nếu bạn cần được trợ giúp thêm về phân đoạn dữ liệu trên nhiều thực thể cơ sở dữ liệu, hãy liên hệ với các chuyên gia Firebase trên Kênh Slack hoặc trên Stack Overflow.