用量與限制

請參閱本指南瞭解 Cloud Firestore 限制,並參閱「Cloud Firestore 定價」一文,進一步瞭解 Cloud Firestore 費用,包括需要留意的事項。

監控使用情況

如要監控 Cloud Firestore 用量,請在 Firebase 控制台中開啟 Cloud Firestore用量」分頁。使用資訊主頁評估不同時間範圍的使用情形。

Google Cloud 控制台中的詳細使用情形

建立 Firebase 專案時,您也會建立 Google Cloud 專案。Google Cloud 控制台的 Cloud Firestore API 配額App Engine 配額頁面會追蹤 Cloud Firestore 用量和配額資訊。

免費配額

Cloud Firestore 提供免費配額,您無須付費即可開始使用 (default) 資料庫。下表列出這個服務提供的各項免費配額。如果您需要更多配額,則須Google Cloud 專案啟用計費功能

您每天可使用的配額有一定的限制,系統會在太平洋時間凌晨 12 點左右重設配額。

只有 (default) 資料庫才符合免費配額的資格。

免費方案 配額
儲存的資料量 1 GiB
文件讀取次數 每天 50,000 次
文件寫入次數 每天 20,000 次
文件刪除次數 每天 20,000 次
傳出資料移轉 每月 10 GiB

下列作業和功能不包含免費用量。 您必須啟用結帳功能,才能使用下列功能:

  • 使用命名 (非預設) 資料庫
  • 存留時間刪除
  • PITR 資料
  • 備份資料
  • 復原作業

如要進一步瞭解這些功能的計費方式,請參閱「儲存空間定價」。

標準限制

下表列出 Cloud Firestore 的適用限制。除非另有說明,否則這些都是硬性限制。

資料庫

限制 詳細資料
每個專案的資料庫數量上限

100

您可以與支援團隊聯絡,要求提高上限。

集合、文件和欄位

限制 說明
集合 ID 限制
  • 必須使用有效的 UTF-8 字元
  • 長度不得超過 1,500 個位元組
  • 不得包含正斜線 (/)
  • 不得僅包含一個半形句號 (.) 或連續兩個半形句號 (..)
  • 不得與以下規則運算式相符:__.*__
子集合深度上限 100
文件 ID 限制
  • 必須使用有效的 UTF-8 字元
  • 長度不得超過 1,500 個位元組
  • 不得包含正斜線 (/)
  • 不得僅包含一個半形句號 (.) 或連續兩個半形句號 (..)
  • 不得與以下規則運算式相符:__.*__
  • 如果將 Datastore 實體匯入到 Firestore 資料庫中,數字實體 ID 會以 __id[0-9]+__ 的形式顯示
檔案名稱大小上限 6 KiB
檔案大小上限 1 MiB (1,048,576 個位元組)
欄位名稱限制
  • 必須使用有效的 UTF-8 字元
  • 不得與以下規則運算式相符:__.*__
欄位名稱大小上限 1,500 個位元組
欄位路徑限制
  • 必須以一個半形句號 (.) 分隔欄位名稱
  • 可傳遞為以點分隔 (.) 的區隔字串,其中每個區隔為簡單欄位名稱或引號欄位名稱 (定義如下)。
如果欄位名稱符合以下所有條件,即為簡單的名稱:
  • 僅含 a-zA-Z0-9 等字元和底線 (_)
  • 開頭不是 0-9
引號欄位名稱的開頭和結尾都是反引號字元 (`)。舉例來說,foo.`x&y` 是指在 foo 欄位下巢狀嵌套的 x&y 欄位。如要使用反斜線字元建構含有反斜線字元的欄位名稱,請使用反斜線字元 (\) 逸出反斜線字元。為方便起見,您可以將欄位路徑做為 FieldPath 物件傳遞,藉此避免使用引號標記的欄位名稱 (例如,請參閱 JavaScript FieldPath)。
欄位路徑大小上限 1,500 個位元組
欄位值大小上限 1 MiB 減去 89 個位元組 (1,048,487 個位元組)
對應關係或陣列中欄位的深度上限

20

對應和陣列欄位會為物件的整體深度新增一個等級。舉例來說,下列物件總深度為三個層級:


{
  nested_map: {         #depth 1
    nested_array: [     #depth 2
      {
        foo: "bar"      #depth 3
      }
    ]
  }
}
      

寫入作業和交易

除了這些限制之外,您也應參閱設計可擴充規模的最佳做法

限制 說明
API 請求大小上限 10 MiB
交易時間限制 270 秒,閒置到期時間為 60 秒
可在一項 Commit 作業或交易中對一個文件執行的欄位轉換工作數量上限 500

索引

下列限制適用於單一欄位索引複合式索引

限制 說明
資料庫的複合式索引數量上限
資料庫的單一欄位設定數量上限
  • 200,如果您尚未為 Google Cloud 專案啟用計費功能。

    如果您需要更多配額,則必須Google Cloud 專案啟用計費功能

  • 500 美元 (如果您為 Google Cloud 專案啟用計費功能)。

一個欄位層級設定可以包含同一個欄位的多個設定。舉例來說,單一欄位索引豁免和同一個欄位的 TTL 政策,在限制方面會計為一個欄位設定。

每個文件的索引項目數量上限

40,000 個

索引項目數量是文件中下列兩種項目的總和:

  • 單一欄位索引項目的數量
  • 複合式索引項目的數量

如要瞭解 Cloud Firestore 如何將文件和一組索引轉換為索引項目,請參閱這個索引項目計數範例

複合式索引中的欄位數量上限 100
索引項目大小上限

7.5 KiB

如要瞭解 Cloud Firestore 計算索引項目大小的方式,請參閱「索引項目大小」一節。

文件的索引項目大小總和上限

8 MiB

大小總計是文件中下列兩種項目的總和:

  • 文件的單一欄位索引項目大小總和
  • 文件的複合式索引項目大小總和
  • 已建立索引的欄位值大小上限

    1500 個位元組

    超過 1500 個位元組的欄位值會遭到截斷。如果查詢中有欄位值遭截斷,系統可能會傳回不一致的結果。

    存留時間 (TTL)

    限制 詳細資料
    資料庫的單一欄位設定數量上限
    • 200,如果您尚未為 Google Cloud 專案啟用計費功能。

      如果您需要更多配額,則必須Google Cloud 專案啟用計費功能

    • 500 美元 (如果您為 Google Cloud 專案啟用計費功能)。

    一個欄位層級設定可以包含同一個欄位的多個設定。舉例來說,單一欄位索引豁免和同一個欄位的 TTL 政策,在限制方面會計為一個欄位設定。

    匯出/匯入

    以下限制適用於代管匯入及匯出作業

    限制 說明
    專案每分鐘允許的匯出與匯入要求總數上限 20
    並行匯出與匯入作業的數量上限 50
    匯出與匯入要求的集合 ID 篩選器數量上限 100

    安全性規則

    限制 說明
    每項要求的 exists()get()getAfter() 呼叫數量上限
    • 單一文件要求和查詢要求的上限為 10 項。
    • 多文件讀取作業、交易和批次寫入作業的上限為 20 項。上述限制 (10 項呼叫) 同樣適用於各項作業。

      舉例來說,假設您建立的批次寫入要求含有 3 項寫入作業,而您的安全性規則會使用 2 項文件存取呼叫來驗證各項寫入作業。此時,各項寫入作業會使用 2 項存取呼叫 (上限為 10 項),批次寫入要求則會使用 6 項存取呼叫 (上限為 20 項)。

    超過任一項限制都會引發權限遭拒的錯誤。

    系統可能會快取部分的文件存取呼叫,已快取的呼叫不會計入限制中。

    巢狀 match 陳述式深度上限 10
    一組巢狀 match 陳述式中允許的路徑長度上限 (以路徑區段為單位) 100
    一組巢狀 match 陳述式中允許的路徑擷取變數數量上限 20
    函式呼叫深度上限 20
    函式引數數量上限 7
    每個函式的 let 變數繫結上限 10
    遞迴或循環函式呼叫的數量上限 0 (不允許)
    每個要求中經評估的運算式數量上限 1,000 個
    規則集的大小上限 規則集必須遵守下列兩項大小限制:
    • 如果使用 firebase deployFirebase 主控台或 CLI 發布規則集文字來源,大小限制為 256 KB。
    • Firebase 處理來源並在後端加以啟用時,所產生之已編譯規則集的大小限制為 250 KB。

    管理支出

    為避免帳單產生非預期的費用,請設定每月預算與快訊。

    設定每月預算

    如要追蹤 Cloud Firestore 費用,請在 Google Cloud 控制台中建立每月預算。預算並不會限制您的用量,但您可以設定快訊,讓系統在您即將達到或超出預估的當月費用時通知您。

    如要設定預算,請前往 Google Cloud 控制台的「Billing」部分,為 Cloud Billing 帳戶建立預算。您可以使用預設快訊設定,也可以修改快訊,在每月預算的不同百分比傳送通知。

    進一步瞭解如何設定預算和預算快訊