Utilizzo di Cloud Firestore in modalità Datastore

Firestore è un database di documenti NoSQL creato per offrire scalabilità automatica, prestazioni elevate e facilità di sviluppo delle applicazioni. È la versione più recente di Datastore e introduce diversi miglioramenti rispetto a Datastore.

Poiché Firestore in modalità Datastore è ottimizzato per i casi d'uso dei server e per App Engine, consigliamo di utilizzare Firestore in modalità Datastore per i database che verranno utilizzati principalmente dalle app App Engine. Firestore in modalità Native è più utile per i casi d'uso di notifiche mobile e in tempo reale. Per ulteriori informazioni sulle modalità Firestore, consulta Scegliere tra la modalità Native e la modalità Datastore.

Utilizzo della modalità Datastore con App Engine

Per utilizzare la modalità Datastore con App Engine:

  1. Se non l'hai ancora fatto, crea un database e scegli Firestore in modalità Datastore.

    Puoi utilizzare i database Datastore esistenti con le app App Engine. Per questi database esistenti verrà eseguito automaticamente l'upgrade a Firestore in modalità Datastore.

  2. Utilizzare Cloud NDB)

    per creare, recuperare e gestire le entità nel database in modalità Datastore.

Se prevedi di eseguire l'upgrade della tua app Python 2 a Python 3, hai a disposizione alcune opzioni:

  • Se la tua app Python 2 utilizza App Engine NDB per interagire con Datastore, ti consigliamo di eseguire la migrazione a Cloud NDB anziché alla libreria client in modalità Datastore, in quanto la prima offre un'esperienza utente molto più simile.

  • Puoi anche scegliere di eseguire prima il porting dell'app Python 2 che utilizza App Engine NDB a Python 3 e poi eseguire la migrazione a Cloud NDB. Per scoprire come accedere a App Engine NDB in Python 3, consulta la pagina Accesso ai servizi di App Engine in bundle per Python 3.

Per risorse aggiuntive e un esempio di migrazione da un'app webappin Python 2 che utilizza App Engine NDB a un'app Flask in Python 3 equivalente con App Engine NDB attivato, consulta la pagina dei servizi in bundle per Python 3.

Configurazione degli indici

La modalità Datastore utilizza indici per ogni query eseguita dalla tua applicazione. Gli indici vengono aggiornati ogni volta che un'entità cambia, in modo che i risultati possano essere restituiti rapidamente quando l'app esegue una query.

La modalità Datastore crea automaticamente indici a proprietà singola da utilizzare con tipi di query semplici. Per query complesse che includono più proprietà, devi configurare gli indici composti nel file index.yaml dell'app.

Il server di sviluppo App Engine aggiornerà il file index.yaml con gli indici composti necessari per eseguire i test. Analogamente, l'emulatore della modalità Datastore può generare indici quando esegui i test.

Puoi anche aggiungere gli indici al file index.yaml della tua app manualmente se non esegui test locali o se i tuoi test non includono query complesse.

Impostazione delle autorizzazioni di accesso al database

Per impostazione predefinita, la tua app dispone di tutte le autorizzazioni necessarie per leggere e scrivere nei database in modalità Datastore e Firestore nel tuo progetto Google Cloud.

Per gestire queste autorizzazioni, ogni app App Engine utilizza un account di servizio predefinito che concede l'accesso in lettura e scrittura completo alla modalità Datastore e ai database Firestore nello stesso progetto dell'app. Puoi modificare le autorizzazioni dell'account di servizio predefinito, ma la tua app potrebbe perdere l'accesso a meno che non assegni un ruolo IAM con le autorizzazioni richieste.

Per informazioni su come consentire ad altri utenti, app o progetti di accedere a un database, consulta Accedere al database.

Prezzi, quote e limiti

La modalità Datastore offre una quota gratuita con limiti giornalieri. Gli account pagati offrono operazioni di lettura, scrittura e spazio di archiviazione illimitato. Ulteriori informazioni sono disponibili nella pagina Quote di Datastore.