剖析資料庫

使用 Firebase CLI 內建的資料庫剖析器工具,評估 Firebase Realtime Database 的效能。分析器工具 然後在資料庫內的活動量產生 詳細報表您可以使用詳細報表排解資料庫效能問題、找出問題區域,並減少未編入索引的查詢。

建立個人資料

  1. 開始剖析 Firebase Realtime Database 之前,請確認您使用的是最新版 Firebase CLI,且已針對要剖析的資料庫和專案將其初始化。注意事項 您必須是該專案的編輯者或擁有者,才能剖析專案

  2. 使用下列指令開始剖析資料庫:

    firebase database:profile
    在分析器從您的資源記錄作業開始時,分析器會顯示狀態訊息 資料庫並建立設定檔

  3. 按下 Enter 鍵即可完成設定,並顯示結果。

解讀結果

剖析工具會匯總收集到的資料庫作業資料,並將結果分為三個主要類別:速度頻寬未編入索引的查詢

速度

速度報表會測量伺服器針對 作業類型。不過,速度報告中測得的速度可能並非實際反映使用者體驗的速度。各種因素,包括 網路狀況可能會增加用戶端的延遲時間

速度報表包含下列屬性:

  • 路徑:資料庫中執行作業的路徑。如果 有超過 25 個子節點,分析器工具會將其收合為 並新增 $wildcard 標記。您可能會看見資料庫的 報表的根目錄,以正斜線 / 表示。
  • 計數:在指定路徑發生的作業數。
  • 平均執行速度:伺服器執行所需的平均時間 處理該路徑中特定作業類型所需的商業邏輯。 此處測量的時間間隔是從 Pending Time」。
  • 平均待處理時間:要求在排入佇列後,等待執行的平均時間。所有由用戶端發起的要求都會出現這種延遲現象。 伺服器端要求的總延遲時間大致等於該要求 待處理時間和執行速度
  • 權限遭拒:指定的作業數量 已遭封鎖 Firebase 資料庫規則 資料庫內的項目
按照作業類型顯示速度報表
讀取執行速度 用戶端要求從資料庫讀取資料的伺服器回應時間。讀取執行時間通常會隨著讀取的資料量而調整,但即使是一些小型讀取作業,也可能會因快取預先載入而延遲。
寫入執行速度 用戶端要求將資料寫入 資料庫寫入執行時間會隨著寫入的資料量而調整。
連線執行速度 對資料庫用戶端建立要求的伺服器回應時間。 連線要求的延遲時間主要受到與連線管理相關的記憶體內伺服器端記帳影響。
廣播執行速度

伺服器將資料分發至偵聽指定路徑的用戶端,以便即時更新所需的時間。

廣播速度報表中的「Count」屬性會匯總發生的廣播數量,而非收到資訊的用戶端數量。舉例來說,如果有 10 個用戶端在特定路徑上進行監聽,且伺服器向所有 10 個用戶端廣播更新,則廣播計數只會反映 1 次廣播,即使 10 個用戶端都收到資料。

播送速度報表中不包含「Permission Denied」屬性。

頻寬

「頻寬」報表可提供洞察資料,讓您瞭解資料庫在傳入和傳出作業中消耗了多少資料。請不要使用頻寬 提供預估帳單的報表,因為未涵蓋所用頻寬 執行其他作業,例如剖析資料庫。 頻寬報表可粗略估算資料庫讀取、寫入和廣播作業所消耗資料的酬載大小。這項工具是用來評估成效,而非預測帳單。

頻寬報表包含下列屬性:

  • Path:發生作業的資料庫路徑。如果子節點超過 25 個,剖析器工具會將這些節點折疊至父項路徑。

  • 總計:所有作業使用傳出或傳入的位元組總數 和預測路徑

  • 計數:在指定路徑發生的作業數。

  • 平均:所有使用者下載或上傳的平均位元組數 都位於指定路徑 (位元組/寫入或位元組/讀取) 時。

頻寬報表
已下載的位元組 透過用戶端 SDK 和 REST API 傳送的讀取和廣播作業所消耗的資料。
上傳的位元組 透過寫入要求進入資料庫伺服器的資料用量。刪除作業會顯示為寫入作業,且在「傳入」下方顯示為 0 位元組。

未建立索引的查詢

未編入索引的查詢可能會耗費大量資源,因為用戶端會下載某個位置的所有資料,然後對其執行查詢。這會導致不必要的頻寬用量增加。盡可能解決最多的未建立索引查詢,以便最佳化 例如資料庫效能

「未建立索引的查詢」報表會顯示下列屬性:

  • Path:資料庫中發生未編入索引查詢的路徑。
  • 索引:應新增的規則來解決未建立索引的查詢。學習新知 請參閱為資料建立索引一文,進一步瞭解如何建立索引。
  • 計數:在指定路徑中發生的未建立索引查詢數量。

進階剖析

如要查看資料庫處理的所有作業,請使用 --raw 旗標,如下所示:

firebase database:profile --raw

原始輸出內容還包含每個作業的用戶端資訊,例如 userAgent 字串和 IP 位址。進一步瞭解各種作業 是在 Firebase Realtime Database 作業類型中的 Firebase Realtime Database 剖析。

分析器工具:非帳單工具

請勿使用分析工具來估算頻寬成本。剖析工具旨在提供資料庫效能的整體情況,協助您監控作業並排解問題,而非用於估算帳單費用。這項指標不會計算網路流量,只會記錄回應中傳送的應用程式資料預估值。

以下列舉 Firebase 會計費的網路流量,但資料庫設定檔未涵蓋的常見情況:

  • 協定額外負擔:建立及維持工作階段時,伺服器和用戶端之間需要額外的流量。視底層通訊協定而定,這類流量可能包括:Firebase 即時資料庫的即時通訊協定額外負擔、WebSocket 額外負擔,以及 HTTP 標頭額外負擔。每次建立連線時,這項開銷加上任何 SSL 加密開銷,都會增加連線成本。雖然這通常 需要大量頻寬,如果您的裝載是極小的,則可能很龐大 或是頻繁、短時間內連結
  • SSL 加密額外負擔:SSL 加密額外負擔是安全連線所需的必要成本。平均而言,初始握手的成本約為 3.5 KB,每則傳出訊息的 TLS 記錄標頭約為 40 B。對大多數應用程式來說 佔了帳單的百分比然而,如果 確實需要大量的 SSL 交握。例如裝置 不支援 TLS 工作階段票證的 KPI 可能需要大量的 SSL 連線握手

進一步瞭解如何查看及估算帳單金額