Lập hồ sơ cơ sở dữ liệu của bạn

Đo lường hiệu suất của Firebase Realtime Database bằng công cụ trình phân tích cơ sở dữ liệu được tích hợp vào Firebase CLI. Công cụ phân tích tài nguyên ghi lại tất cả hoạt động trong cơ sở dữ liệu của bạn trong một khoảng thời gian nhất định, sau đó tạo một báo cáo chi tiết. Hãy sử dụng báo cáo chi tiết để khắc phục các vấn đề về hiệu suất cơ sở dữ liệu, phát hiện các vấn đề và giảm số lượng truy vấn chưa được lập chỉ mục.

Tạo hồ sơ

  1. Trước khi bắt đầu lập hồ sơ Firebase Realtime Database, hãy đảm bảo bạn đang sử dụng phiên bản mới nhất của Firebase CLI và bạn đã khởi chạy phiên bản này cho cơ sở dữ liệu và dự án mà bạn muốn lập hồ sơ. Xin lưu ý rằng bạn phải là người chỉnh sửa hoặc chủ sở hữu của dự án đó thì mới có thể lập hồ sơ.

  2. Bắt đầu phân tích cơ sở dữ liệu bằng lệnh sau:

    firebase database:profile
    Trình phân tích tài nguyên hiển thị thông báo trạng thái khi ghi lại các thao tác từ cơ sở dữ liệu và tạo hồ sơ.

  3. Nhấn phím Enter để hoàn tất hồ sơ và hiển thị kết quả.

Diễn giải kết quả

Công cụ phân tích tài nguyên tổng hợp dữ liệu đã thu thập về các thao tác của cơ sở dữ liệu và hiển thị kết quả theo 3 danh mục chính: tốc độ, băng thôngtruy vấn chưa được lập chỉ mục.

Tốc độ

Báo cáo tốc độ đo lường thời gian phản hồi của máy chủ (tính bằng mili giây) cho từng loại thao tác. Tuy nhiên, tốc độ được đo trong Báo cáo tốc độ có thể không phản ánh chính xác tốc độ mà người dùng cuối trải nghiệm. Nhiều yếu tố, bao gồm cả điều kiện mạng, có thể làm tăng độ trễ ở phía máy khách.

Báo cáo Tốc độ bao gồm các thuộc tính sau:

  • Đường dẫn: Đường dẫn trong cơ sở dữ liệu của bạn nơi các thao tác xảy ra. Nếu có nhiều hơn 25 nút con, công cụ phân tích tài nguyên sẽ thu gọn các nút này thành một đường dẫn mẹ và thêm một điểm đánh dấu $wildcard. Bạn có thể thấy thư mục gốc của cơ sở dữ liệu trong báo cáo, được biểu thị bằng dấu gạch chéo xuôi /.
  • Số lượng: Số lượng thao tác xảy ra tại đường dẫn đã cho.
  • Tốc độ thực thi trung bình: Thời gian trung bình mà máy chủ cần để thực thi logic nghiệp vụ cần thiết để xử lý loại thao tác cụ thể tại đường dẫn đó. Khoảng thời gian được đo lường tại đây bắt đầu sau khoảng thời gian được đo lường bằng "Thời gian trung bình đang chờ xử lý" được mô tả bên dưới.
  • Thời gian chờ trung bình: Thời gian trung bình mà các yêu cầu dành cho hàng đợi trước khi được thực thi. Sự chậm trễ này thường xảy ra với tất cả các yêu cầu do ứng dụng khởi tạo. Tổng độ trễ của yêu cầu phía máy chủ gần bằng tổng thời gian chờ và tốc độ thực thi của yêu cầu đó.
  • Quyền bị từ chối: Số lượng thao tác tại đường dẫn đã cho bị Quy tắc cơ sở dữ liệu Firebase chặn trên cơ sở dữ liệu của bạn.
Báo cáo tốc độ theo Loại thao tác
Tốc độ thực thi đọc Thời gian phản hồi của máy chủ đối với các yêu cầu của ứng dụng để đọc dữ liệu từ cơ sở dữ liệu. Thời gian thực thi đọc thường tỷ lệ với lượng dữ liệu đang được đọc, nhưng ngay cả một số lượt đọc nhỏ cũng có thể bị trì hoãn do tính năng tìm nạp trước bộ nhớ đệm.
Tốc độ thực thi ghi Thời gian phản hồi của máy chủ đối với các yêu cầu của ứng dụng để ghi dữ liệu vào cơ sở dữ liệu. Ghi các thang thời gian thực thi với lượng dữ liệu đang được ghi.
Tốc độ thực thi Connect Thời gian phản hồi của máy chủ đối với các yêu cầu thiết lập với ứng dụng cơ sở dữ liệu. Độ trễ của các yêu cầu kết nối chủ yếu là do hoạt động ghi sổ phía máy chủ trong bộ nhớ liên quan đến việc quản lý kết nối.
Tốc độ thực thi thông báo truyền tin

Khoảng thời gian máy chủ cần để phân phối dữ liệu cho các ứng dụng đang theo dõi đường dẫn đã cho để cập nhật theo thời gian thực.

Thuộc tính Số lượng trong Báo cáo tốc độ truyền tin tổng hợp số lượng thông báo truyền tin đã xảy ra, chứ không phải số lượng ứng dụng đã nhận được thông tin. Ví dụ: nếu 10 ứng dụng đang nghe ở một đường dẫn nhất định và máy chủ truyền tin cập nhật cho tất cả 10 ứng dụng, thì số lượng thông báo truyền tin chỉ phản ánh 1 thông báo truyền tin, mặc dù 10 ứng dụng đã nhận được dữ liệu.

Thuộc tính Permission Denied (Từ chối cấp quyền) không có trong báo cáo Tốc độ truyền tin.

Dải thông

Báo cáo băng thông cung cấp thông tin chi tiết về lượng dữ liệu mà cơ sở dữ liệu của bạn tiêu thụ trong các hoạt động đến và đi. Tuy nhiên, bạn không nên sử dụng Báo cáo băng thông để ước tính mức thanh toán vì báo cáo này không bao gồm băng thông dùng cho các hoạt động khác, chẳng hạn như lập hồ sơ cơ sở dữ liệu. Báo cáo băng thông ước tính gần đúng kích thước tải trọng của dữ liệu mà các thao tác đọc, ghi và truyền tin tiêu thụ đến và từ cơ sở dữ liệu của bạn. Đây là công cụ đo lường hiệu suất, chứ không phải công cụ dự báo việc lập hoá đơn.

Báo cáo Băng thông bao gồm các thuộc tính sau:

  • Đường dẫn: Đường dẫn trong cơ sở dữ liệu của bạn nơi các thao tác xảy ra. Nếu có nhiều hơn 25 nút con, công cụ phân tích tài nguyên sẽ thu gọn các nút này thành một đường dẫn mẹ.

  • Tổng: Tổng số byte gửi đi hoặc nhận được được sử dụng trên tất cả các thao tác tại đường dẫn đã cho.

  • Số lượng: Số lượng thao tác xảy ra tại đường dẫn đã cho.

  • Trung bình: Số byte trung bình được tải xuống hoặc tải lên trên các thao tác tại đường dẫn đã cho (byte/ghi hoặc byte/đọc).

Báo cáo băng thông
Số byte đã tải xuống Dữ liệu được sử dụng thông qua các thao tác đọc và truyền tin được gửi qua SDK ứng dụng và API REST.
Số byte đã tải lên Dữ liệu được sử dụng thông qua các yêu cầu ghi vào máy chủ cơ sở dữ liệu. Các lượt xoá sẽ xuất hiện dưới dạng lượt ghi với 0 byte trong phần đến.

Truy vấn chưa được lập chỉ mục

Các truy vấn không được lập chỉ mục có thể tốn kém vì ứng dụng sẽ tải tất cả dữ liệu xuống tại một vị trí rồi thực hiện truy vấn trên dữ liệu đó. Điều này làm tiêu tốn nhiều băng thông hơn mức cần thiết. Giải quyết nhiều truy vấn chưa được lập chỉ mục nhất có thể để tối ưu hoá hiệu suất của cơ sở dữ liệu.

Báo cáo Truy vấn không được lập chỉ mục hiển thị các thuộc tính sau:

  • Đường dẫn: Đường dẫn trong cơ sở dữ liệu của bạn nơi xảy ra các truy vấn chưa được lập chỉ mục.
  • Chỉ mục: Quy tắc bạn nên thêm để phân giải các truy vấn chưa được lập chỉ mục. Tìm hiểu thêm về việc lập chỉ mục trong bài viết Lập chỉ mục dữ liệu.
  • Số lượng: Số lượng truy vấn chưa được lập chỉ mục xảy ra tại đường dẫn đã cho.

Phân tích tài nguyên nâng cao

Để xem tất cả các thao tác mà cơ sở dữ liệu của bạn đang xử lý, hãy sử dụng cờ --raw khi bạn lập hồ sơ cơ sở dữ liệu như sau:

firebase database:profile --raw

Kết quả thô cũng bao gồm thông tin về ứng dụng cho mỗi thao tác, chẳng hạn như chuỗi userAgent và địa chỉ IP. Tìm hiểu thêm về các thao tác khác nhau được phân tích trong Firebase Realtime Database trong phần Các loại thao tác Firebase Realtime Database.

Công cụ phân tích tài nguyên: Không phải là công cụ thanh toán

Đừng sử dụng công cụ phân tích tài nguyên để ước tính chi phí băng thông. Công cụ phân tích tài nguyên nhằm cung cấp cho bạn thông tin tổng quan về hiệu suất của cơ sở dữ liệu, giúp bạn theo dõi hoạt động và khắc phục sự cố, chứ không phải để ước tính phí. Chỉ số này không tính đến lưu lượng truy cập mạng, mà chỉ ghi lại số liệu ước tính về dữ liệu ứng dụng được gửi trong các phản hồi.

Sau đây là một số ví dụ phổ biến về lưu lượng truy cập mạng do Firebase tính phí mà không được đề cập trong hồ sơ cơ sở dữ liệu của bạn:

  • Mức hao tổn giao thức: Cần có một số lưu lượng truy cập bổ sung giữa máy chủ và ứng dụng để thiết lập và duy trì phiên. Tuỳ thuộc vào giao thức cơ bản, lưu lượng truy cập này có thể bao gồm: hao tổn giao thức theo thời gian thực của Cơ sở dữ liệu theo thời gian thực của Firebase, hao tổn WebSocket và hao tổn tiêu đề HTTP. Mỗi khi một kết nối được thiết lập, chi phí này, kết hợp với mọi chi phí mã hoá SSL, sẽ góp phần làm tăng chi phí kết nối. Mặc dù thường không phải là một lượng băng thông lớn, nhưng lượng băng thông này có thể đáng kể nếu tải trọng của bạn rất nhỏ hoặc bạn thường xuyên tạo các kết nối ngắn.
  • Chi phí mã hoá SSL: Có một chi phí liên quan đến chi phí mã hoá SSL cần thiết cho các kết nối bảo mật. Trung bình, chi phí này là khoảng 3, 5 KB cho lượt bắt tay ban đầu và khoảng 40 B cho tiêu đề bản ghi TLS trên mỗi thư gửi đi. Đối với hầu hết ứng dụng, đây là một tỷ lệ nhỏ trong hoá đơn của bạn. Tuy nhiên, tỷ lệ này có thể trở thành một con số lớn nếu trường hợp cụ thể của bạn yêu cầu nhiều lượt bắt tay SSL. Ví dụ: các thiết bị không hỗ trợ vé phiên TLS có thể yêu cầu số lượng lớn các lượt bắt tay kết nối SSL.

Đọc thêm về cách tìm hiểu và ước tính hoá đơn.