Speichergrößenberechnungen

Auf dieser Seite wird die Speichergröße von Dokumenten, Feldern und Indexeinträgen in Firestore mit MongoDB-Kompatibilität beschrieben.

Im Abschnitt Cloud Firestore Enterprise-Version – Preise finden Sie weitere Informationen zu den Kosten dieser Speichermethode.

Stringgröße

Die Größe der Strings berechnet sich aus der Anzahl der UTF-8-codierten Byte + 1.

Die nachfolgenden Elemente werden als String gespeichert:

  • Name der Sammlung
  • Feldnamen
  • Stringfeldwerte (einschließlich _id)

Beispiel:

  • Der Sammlungsname tasks verwendet 5 Byte + 1 Byte, also insgesamt 6 Byte.
  • Der Feldname description verwendet 11 Byte + 1 Byte, also insgesamt 12 Byte.

Feldwertgröße

Die folgende Tabelle zeigt die Größe der Feldwerte nach Typ an.

Typ Größe
Array Die Summe der Wertgrößen
Boolean 1 Byte
Binärdaten Byte-Länge + 1 für einen nicht generischen (nicht 0) Untertyp
Datum 8 Byte
Doppelt 8 Byte
Double128 16 Byte
32-Bit-Ganzzahl Byte
64-Bit-Ganzzahl (lang) 8 Byte
Objekt Die Summe der Stringgrößen der einzelnen Feldnamen und der Größen der einzelnen Feldwerte im eingebetteten Objekt
Min-Schlüssel 1 Byte
Max-Schlüssel 1 Byte
Null 1 Byte
Regulärer Ausdruck (Länge des Musters + 1) + (Länge der Optionen + 1)
Zeitstempel 8 Byte
String Anzahl der UTF-8-kodierten Byte + 1

Ein boolesches Feld mit dem Namen done würde beispielsweise 6 Byte verwenden:

  • 5 Byte für den Feldnamen done
  • 1 Byte für den booleschen Wert

Dokumentgröße

Die Größe eines Dokuments ist die Summe aus folgenden Komponenten:

  • Die Stringgröße des Sammlungsnamens
  • Die Summe der Stringgröße jedes Feldnamens (außer _id)
  • Die Summe der Größe jedes Feldwerts (einschließlich _id)
  • 48 zusätzliche Byte

Dieses Beispiel bezieht sich auf ein Dokument in der Sammlung tasks:

{
  "_id": "my_task_id",
  "type": "Personal",
  "done": false,
  "priority": 1,
  "description": "Learn Cloud Firestore"
}

Die Gesamtgröße der Felder beträgt 78 Byte:

Feldname und -wert Feldgröße in Byte
"_id": "my_task_id" 11 für den Stringwert des Felds
"type": "Personal" 14
5 für den Feldnamen + 9 für den Stringwert des Felds
"done": false 6
5 für den Feldnamen + 1 für den booleschen Wert des Felds
"priority": 1 17
9 für den Feldnamen + 4 für den 32-Bit-Ganzzahlwert des Felds
"description": "Learn Cloud Firestore" 34
12 für den Feldnamen + 22 für den Stringwert des Felds

Die Dokumentgröße beträgt also 6 + 78 + 48 = 132 Byte:

  • 6 für den Sammlungsnamen
  • 78 Byte für die Felder
  • 48 zusätzliche Byte

Größe des Indexeintrags

Die Größe eines Indexeintrags in einem Index ist die Summe aus folgenden Komponenten:

  • Die Stringgröße des Sammlungsnamens
  • Die Größe des Feldwerts _id
  • Summe der indexierten Feldwerte
  • 48 zusätzliche Byte

Betrachten Sie ein Dokument in der Sammlung tasks:

{
  "_id": "my_task_id",
  "type": "Personal",
  "done": false,
  "priority": 1,
  "description": "Learn Cloud Firestore"
}

Bei einem Index für die Felder done und priority (beide aufsteigend) beträgt die Gesamtgröße des Indexeintrags in diesem Index 70 Byte:

  • 6 Byte für den Sammlungsnamen tasks
  • 11 Byte für den Feldwert _id
  • 1 Byte für den booleschen Feldwert
  • 4 Byte für den Wert des 32-Bit-Ganzzahlfelds
  • 48 zusätzliche Byte

Bei dünnbesetzten Indizes wird kein Indexeintrag erstellt, wenn ein Dokument keines der Felder enthält. Wenn ein Dokument mindestens eines der indexierten Felder enthält, wird ein Indexeintrag erstellt, in dem die fehlenden indexierten Felder auf NULL gesetzt sind.

Nächste Schritte

Informationen zu den Preisen für die Firestore Enterprise-Version