Calcoli dello spazio di archiviazione
Questa pagina descrive le dimensioni di archiviazione di documenti, campi e voci di indice in Firestore con compatibilità MongoDB.
Puoi scoprire di più sui costi di questo spazio di archiviazione nella pagina dei prezzi.
Dimensioni della stringa
Le dimensioni delle stringhe vengono calcolate come il numero di byte codificati UTF-8 + 1.
Di seguito sono riportati gli elementi archiviati come stringhe:
- Nome raccolta
- Nomi dei campi
- Valori dei campi stringa (incluso
_id)
Ad esempio:
- Il nome della raccolta
tasksutilizza 5 byte + 1 byte, per un totale di 6 byte. - Il nome del campo
descriptionutilizza 11 byte + 1 byte, per un totale di 12 byte.
Dimensioni del valore del campo
La tabella seguente mostra le dimensioni dei valori dei campi per tipo.
| Tipo | Dimensioni |
|---|---|
| Array | La somma delle dimensioni dei relativi valori |
| Booleano | 1 byte |
| Dati binari | Lunghezza in byte + 1 per un sottotipo non generico (non 0) |
| Data | 8 byte |
| Doppio | 8 byte |
| Double128 | 16 byte |
| Numero intero a 32 bit | 4 byte |
| Numero intero a 64 bit (long) | 8 byte |
| Oggetto | La somma delle dimensioni delle stringhe di ogni nome di campo e delle dimensioni di ogni valore di campo nell'oggetto incorporato |
| Chiave minima | 1 byte |
| Chiave massima | 1 byte |
| Null | 1 byte |
| Espressione regolare | (Lunghezza pattern + 1) + (Lunghezza opzioni + 1) |
| Timestamp | 8 byte |
| Stringa | Numero di byte codificati UTF-8 + 1 |
Ad esempio, un campo booleano denominato done utilizzerebbe 6 byte:
- 5 byte per il nome del campo
done - 1 byte per il valore booleano del campo
Dimensioni del documento
Le dimensioni di un documento sono la somma di:
- Le dimensioni della stringa del nome della raccolta
- La somma delle dimensioni della stringa di ogni nome di campo (tranne
_id) - La somma delle dimensioni di ogni valore di campo (incluso
_id) - 48 byte aggiuntivi
Questo esempio riguarda un documento nella raccolta tasks:
{
"_id": "my_task_id",
"type": "Personal",
"done": false,
"priority": 1,
"description": "Learn Cloud Firestore"
}
Le dimensioni totali dei campi sono 78 byte:
| Nome e valore del campo | Dimensioni del campo in byte |
|---|---|
"_id": "my_task_id" |
11 per il valore stringa del campo |
"type": "Personal" |
14 5 per il nome del campo + 9 per il valore stringa del campo |
"done": false |
6 5 per il nome del campo + 1 per il valore booleano del campo |
"priority": 1 |
17 9 per il nome del campo + 4 per il valore intero a 32 bit del campo |
"description": "Learn Cloud Firestore" |
34 12 per il nome del campo + 22 per il valore stringa del campo |
Pertanto, le dimensioni del documento sono 6 + 78 + 48 = 132 byte:
- 6 per il nome della raccolta
- 78 byte per i campi
- 48 byte aggiuntivi
Dimensioni della voce di indice
Le dimensioni di una voce di indice in un indice sono la somma di:
- Le dimensioni della stringa del nome della raccolta
- Le dimensioni del valore del campo
_id - La somma dei valori dei campi indicizzati
- 48 byte aggiuntivi
Considera un documento nella raccolta tasks:
{
"_id": "my_task_id",
"type": "Personal",
"done": false,
"priority": 1,
"description": "Learn Cloud Firestore"
}
Per un indice sui campi done e priority (entrambi in ordine crescente), le dimensioni totali della voce di indice in questo indice sono 70 byte:
- 6 byte per il nome della raccolta
tasks - 11 byte per il valore del campo
_id - 1 byte per il valore del campo booleano
- 4 byte per il valore del campo intero a 32 bit
- 48 byte aggiuntivi
Per gli indici sparsi, se un documento non include nessuno dei campi, non viene creata alcuna voce di indice. Se un documento contiene almeno uno dei campi indicizzati, viene creata una voce di indice con i campi indicizzati mancanti impostati su NULL.
Dimensioni della voce dell'evento del flusso di modifiche
Le dimensioni di un evento del flusso di modifiche sono il totale di:
- La somma delle dimensioni della stringa del nome della raccolta (x2).
- Per gli eventi di inserimento e aggiornamento di un documento:
- La somma delle dimensioni della stringa di ogni nome di campo in
fullDocumentoupdateDescription(tranne_id). - La somma delle dimensioni di ogni valore di campo in
fullDocumentoupdateDescription. (incluso_id).
- La somma delle dimensioni della stringa di ogni nome di campo in
- Se applicabile alle transazioni multi-documento, 24 byte aggiuntivi per
lsidetxnNumber. - 92 byte aggiuntivi
Considera un esempio di evento di inserimento per un documento nella raccolta tasks:
{
"_id": { <Resume Token> },
"operationType": "insert",
"clusterTime": <Timestamp>,
"wallTime": <ISODate>,
"ns": {
"db": "db",
"coll": "tasks"
},
"documentKey": {
"_id": "my_task_id"
},
"fullDocument": {
"_id": "my_task_id",
"description": "Learn Cloud Firestore"
},
}
Le dimensioni totali dell'evento del flusso di modifiche sono 149 byte:
- 92 byte per i metadati generali
- 12 byte in base al nome della raccolta
tasks(6 byte) * 2 - 11 byte per il valore del campo
_id - 12 byte per il nome del campo
description - 22 byte per il valore del campo
description
Dimensioni della voce dell'indice di ricerca testuale
Le dimensioni di una voce dell'indice di ricerca testuale in un indice sono la somma di:
- Le dimensioni della stringa del nome della raccolta
- Le dimensioni del valore
_id - La somma dei byte dei valori dei campi indicizzati (x2)
- 48 byte aggiuntivi per i metadati generali
Considera un esempio di evento di inserimento per un documento con _id my_task_id
nella raccolta tasks:
{ "_id": "my_place", "type": "Restaurant", "visited": false, "priority": 1, "location": GeoPoint(longitude, latitude) }
Le dimensioni totali di una voce dell'indice di ricerca testuale su description sono 105 byte in base a:
- 6 byte per il nome della raccolta
tasks - 11 byte per il valore
_id - 44 byte, in base a 22 byte per il campo
descriptionx2 - 48 byte aggiuntivi per i metadati generali
Dimensioni della voce dell'indice geospaziale
Le dimensioni di una voce dell'indice geospaziale in un indice sono la somma di:
- Le dimensioni della stringa del nome della raccolta
- Le dimensioni del valore
_id - 128 byte per ogni punto geografico indicizzato
- 48 byte aggiuntivi per i metadati generali
Considera un esempio di evento di inserimento per un documento con _id my_place nella raccolta places:
{ "_id": "my_place", "type": "Restaurant", "visited": false, "priority": 1, "location": GeoPoint(longitude, latitude) }
Le dimensioni totali di una voce dell'indice geospaziale su location sono 192 byte in base a:
- 7 byte per il nome della raccolta
places - 9 byte per l'ID documento
- 128 byte per il campo
location - 48 byte aggiuntivi per i metadati generali
Passaggi successivi
Scopri di più sui prezzi.